
Goodreads Scraper
epctex/goodreads-scraper
Scrape goodreads.com for data on millions of books. Crawl book details for images, ISBN, author, description, title, buy links, number of reviews, page number, language, and all other details. You can specify search terms, filters, and much more.
The code examples below show how to run the Actor and get its results. To run the code, you need to have an Apify account. Replace <YOUR_API_TOKEN> in the code with your API token, which you can find under Settings > Integrations in Apify Console. Learn mode
import { ApifyClient } from 'apify-client';
// Initialize the ApifyClient with API token
const client = new ApifyClient({
token: '<YOUR_API_TOKEN>',
});
// Prepare Actor input
const input = {
"search": "harry potter",
"startUrls": [
"https://www.goodreads.com/search?q=game+of+thrones&qid=",
"https://www.goodreads.com/book/show/59576065-acceptance",
"https://www.goodreads.com/list/show/1362.Best_History_Books_",
"https://www.goodreads.com/shelf/show/fiction",
"https://www.goodreads.com/genres/business",
"https://www.goodreads.com/author/list/1221698.Neil_Gaiman"
],
"maxItems": 1,
"endPage": 1,
"extendOutputFunction": ($) => { return {} },
"customMapFunction": (object) => { return {...object} },
"proxy": {
"useApifyProxy": true,
"apifyProxyGroups": [
"RESIDENTIAL"
]
}
};
(async () => {
// Run the Actor and wait for it to finish
const run = await client.actor("epctex/goodreads-scraper").call(input);
// Fetch and print Actor results from the run's dataset (if any)
console.log('Results from dataset');
const { items } = await client.dataset(run.defaultDatasetId).listItems();
items.forEach((item) => {
console.dir(item);
});
})();
Developer
Maintained by Community
Actor stats
- 216 users
- 15k runs
- Modified about 6 hours ago
Categories