Actor picture

Twitter Scraper

vdrmota/twitter-scraper

Scrape any Twitter user profile. Creates an unofficial Twitter API to extract tweets, retweets, replies, favorites, and conversation threads with no Twitter API limits. Download your data as HTML table, JSON, CSV, Excel, XML, and use it in spreadsheets, applications, reports, and databases.

No credit card required

Author's avatarVojta Drmota
  • Modified
  • Users1,387
  • Runs366,074

To run the code examples, you need to have an Apify account. Replace <YOUR_API_TOKEN> in the code with your API token. For a more detailed explanation, please read about running actors via the API in Apify Docs.

const { ApifyClient } = require('apify-client');

// Initialize the ApifyClient with API token
const client = new ApifyClient({
    token: '<YOUR_API_TOKEN>',
});

// Prepare actor input
const input = {
    "searchTerms": [
        "Apify"
    ],
    "searchMode": "",
    "mode": "replies",
    "tweetsDesired": 100,
    "proxyConfig": {
        "useApifyProxy": true
    },
    "extendOutputFunction": async ({ data, item, page, request, customData, Apify }) => {
      return item;
    },
    "extendScraperFunction": async ({ page, request, addSearch, addProfile, _, addThread, addEvent, customData, Apify, signal, label }) => {
     
    },
    "customData": {},
    "handlePageTimeoutSecs": 5000,
    "maxRequestRetries": 3,
    "maxIdleTimeoutSecs": 30,
    "initialCookies": []
};

(async () => {
    // Run the actor and wait for it to finish
    const run = await client.actor("vdrmota/twitter-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);
    });
})();