Here’s how to build a Facebook custom audience for free using their built-in graph search feature. This method doesn’t use the API. This is purely gathering data from the public graph search page in a semi-automated way. The advantage of building a custom audience this way is it’s much more intuitive when doing searches and gives you more flexibility than the current software tools I have seen so far.
Download the “Scraper” extension for Google Chrome browser
data:image/s3,"s3://crabby-images/c19d2/c19d20c0e0c638223310e2966d3c22c983e1740b" alt="media_1389397896947.png"
Here’s the link to download the Scraper extension.
Log in to Facebook and do a search for your target audience
data:image/s3,"s3://crabby-images/80d4f/80d4f4f72410b0e8351e29c4965368453b1d9759" alt="media_1389398005606.png"
Quick Tip: To target people that may be a little more engaged with a page, use the “people that like photos by” search – e.g. “people that like photos by Ralph Lauren”.
Right click on the page and select “Scrape Similar…”
data:image/s3,"s3://crabby-images/0896f/0896f0addffb466832e19c67117de75c9cc81dda" alt="media_1389398133503.png"
It doesn’t really matter where you right click becuase you will be replacing the Xpath selector in the next step anyway.
Enter this into the Xpath selector field and click “Scrape” – //div[contains(@data-bt,’id’)]/@data-bt
data:image/s3,"s3://crabby-images/acc14/acc149f63b002c6414aef433ede8b5a78c4f27e6" alt="media_1389398350947.png"
*Disclaimer – This selector path is working at the moment. If Facebook decides to change their page layout or structure then this may not work in the future – //div[contains(@data-bt,’id’)]/@data-bt
What we are doing here is scraping the page for each user’s Facebook ID. Facebook can use this value to build a custom audience for your ads.
Click Export to Google Docs
data:image/s3,"s3://crabby-images/c9547/c9547ba395ff1d30e5595eb39b64842528da9448" alt="media_1389398565632.png"
Delete rows with irrelevant data
data:image/s3,"s3://crabby-images/cb00b/cb00b6c3a600e78d05cd762c01cb253429037c3d" alt="media_1389398948415.png"
You will need to delete any irrelevant data from the spreadsheet. The first 2 rows for example and usually the last row so you are only left with the data that contains user ID’s.
Enter this into the B1 field – =RIGHT(LEFT(A1,FIND(“,”,A1) -1),FIND(“,”,A1) -7)
data:image/s3,"s3://crabby-images/9028b/9028bb35ae048332487b30cdfe23c749a85a46c7" alt="media_1389398678382.png"
This will select only the ID from the first column text. =RIGHT(LEFT(A1,FIND(“,”,A1) -1),FIND(“,”,A1) -7)
Drag that cell down using the crosshair cursor to reproduce that function on other rows
data:image/s3,"s3://crabby-images/6b40e/6b40e3b8b65651fcd8334dee04ae19a4682129c2" alt="media_1389399059921.png"
You can get the crosshair cursor by moving your mouse to the bottom right of the B1 cell.
Copy the contents of that column
data:image/s3,"s3://crabby-images/e3289/e3289aec59baf5d8d855f289d49f7ed8196879f1" alt="media_1389399156258.png"
Open a new Sheet and select “Paste Special” – “Paste values only”
data:image/s3,"s3://crabby-images/d899a/d899ac45ab91d5d482938c4eb73a47f69da68d12" alt="media_1389399236378.png"
This will give you a clean sheet of data that only contains User ID’s ready for export
Select File – Download As – Comma Separated Values
data:image/s3,"s3://crabby-images/a3d1d/a3d1d1b75819196183e67ef7f4c237d45d3cb143" alt="media_1389399345724.png"
Now you can upload this CSV file to Facebook as a custom audience
data:image/s3,"s3://crabby-images/b5e01/b5e01288ea3e799df7392fc4ec2b49d5043a5fcd" alt="media_1389399502797.png"