 
  
 Loftwah's Ultimate Guide to Collecting Twitter/X Followers Data Using Bash & SocialData API
Prerequisites
- API Key from SocialData.tools
- Basic Bash Scripting
- Basic JSON Handling
Loftwah’s Ultimate Guide to Collecting Twitter/X Followers Data Using Bash & SocialData API
Alright, legend, let’s dig in! If you’ve ever wondered how to pull data on who’s following someone on Twitter/X like a tech-savvy sleuth, you’re in the right place. We’re diving into Bash scripts with the SocialData API to fetch all those spicy followers from any Twitter/X user. We’ll craft a script that collects followers data, handles pagination, spits out either JSON or CSV, and even has a “chill mode” (aka test mode) for gathering just a few pages. By the end of this guide, you’ll have a nifty script tailored to your needs, primed to scrape those follower lists like a boss.
Tools of the Trade
Before we get stuck in, you’re going to need a few essentials:
- API Key: Grab one from SocialData.tools. This is your golden ticket to get access.
- cURL and jq: These command-line wizards help make API requests and parse JSON data.
- Install cURL: sudo apt-get install curl -y
- Install jq: sudo apt-get install jq -y
 
- Install cURL: 
- Bash Shell: We’re assuming you’re rocking a Unix-like setup (like a real techie).
What’s in the Script?
This script’s got it all:
- Get User ID: We’ll turn a Twitter/X handle into a user ID.
- Collect Followers Info: Get all the juicy profiles that are following the user.
- Handle Pagination: We’ll manage the next_cursorto grab every last follower.
- Output the Goods: Export in JSON or CSV—whatever floats your boat.
The script is flexible, letting you run in test mode, set the screen name, and pick your output format. Let’s break it down step-by-step.
Step-by-Step Walkthrough
Step 1: Building Your Script
Let’s dive into the full script, tailored with you in mind:
#!/bin/bash
# Replace these with your actual values
API_KEY="YOUR_API_KEY"
SCREEN_NAME="loftwah"
TEST_MODE=false
MAX_PAGES=2
OUTPUT_FORMAT="json"
# Parse input arguments
if [[ $# -eq 0 ]]; then
  echo "Usage: $0 [-t] [-f screen_name] [-o output_format(json/csv)]"
  exit 1
fi
while getopts "tf:o:" opt; do
  case ${opt} in
    t )
      TEST_MODE=true
      ;;
    f )
      SCREEN_NAME="$OPTARG"
      ;;
    o )
      OUTPUT_FORMAT="$OPTARG"
      ;;
    * )
      echo "Usage: $0 [-t] [-f screen_name] [-o output_format(json/csv)]"
      exit 1
      ;;
  esac
done
# Fetch user ID from screen name
get_user_id() {
  local screen_name=$1
  curl -s -X GET "https://api.socialdata.tools/Twitter/X/user/${screen_name}" \
       -H "Authorization: Bearer $API_KEY" \
       -H "Accept: application/json" | jq -r '.id'
}
# Retrieve the user ID using the screen name
USER_ID=$(get_user_id "$SCREEN_NAME")
if [[ -z "$USER_ID" || "$USER_ID" == "null" ]]; then
  echo "Error: Unable to retrieve user ID for screen name $SCREEN_NAME"
  exit 1
fi
# Initial request URL with user_id
URL="https://api.socialdata.tools/Twitter/X/followers/list?user_id=${USER_ID}"
# Function to perform cURL request
get_followers() {
  local url=$1
  curl -s -X GET "$url" \
       -H "Authorization: Bearer $API_KEY" \
       -H "Accept: application/json"
}
# Fetch followers until all pages are retrieved
next_cursor=""
page_count=0
while true; do
  # Append cursor to URL if it's not empty
  if [[ -n "$next_cursor" ]]; then
    url_with_cursor="${URL}&cursor=${next_cursor}"
  else
    url_with_cursor="$URL"
  fi
  # Perform the cURL request
  response=$(get_followers "$url_with_cursor")
  # Check if response contains an error
  if echo "$response" | grep -q '"status":"error"'; then
    echo "Error: $(echo "$response" | jq -r '.message')"
    exit 1
  fi
  # Extract users and next_cursor from the response
  users=$(echo "$response" | jq -c '.users[]')
  next_cursor=$(echo "$response" | jq -r '.next_cursor')
  # Output the users based on selected output format
  echo "$users" | while read user; do
    id=$(echo "$user" | jq -r '.id')
    name=$(echo "$user" | jq -r '.name')
    screen_name=$(echo "$user" | jq -r '.screen_name')
    location=$(echo "$user" | jq -r '.location')
    followers_count=$(echo "$user" | jq -r '.followers_count')
    friends_count=$(echo "$user" | jq -r '.friends_count')
    if [[ "$OUTPUT_FORMAT" == "csv" ]]; then
      echo "$id,$name,$screen_name,$location,$followers_count,$friends_count"
    else
      echo "$user"
    fi
  done
  # Increment page count and check if in test mode
  ((page_count++))
  if [[ "$TEST_MODE" == true && "$page_count" -ge "$MAX_PAGES" ]]; then
    echo "Test mode: Reached maximum of $MAX_PAGES pages. Exiting."
    break
  fi
  # If next_cursor is empty or null, break out of the loop
  if [[ -z "$next_cursor" || "$next_cursor" == "null" ]]; then
    break
  fi
doneStep 2: Command-Line Options
You can tweak the script with these flags:
- -t: This puts the script in test mode. We’ll only grab the first couple of pages (chill vibes only).
- -f- screen_name: Set the Twitter/X handle you want to stalk—err—analyse.
- -o- output_format: Decide on JSON or CSV for your data dump.
If you’re lost, running the script with no args will show you how it’s done.
Step 3: Running the Script Like a Pro
Here’s how you can use this script, with some examples:
- 
JSON output of Loftwah’s followers: ./collect_Twitter/X_followers.sh -f loftwah -o json
- 
CSV output, maybe to check out who’s following Loftwah: ./collect_Twitter/X_followers.sh -f loftwah -o csv > followers_data.csv
- 
Run it in test mode for just a taste: ./collect_Twitter/X_followers.sh -t -f loftwah -o csv
Step 4: Output Options
- JSON: Good if you need structure or plan to feed it into another app/script.
- CSV: Classic, simple, and perfect for spreadsheets.
Wanna save the output? Redirect it with > like the good ol’ days.
Step 5: The Details You Need
- Argument Parsing: We use getoptsto handle optional flags and keep things flexible.
- Get User ID: We call the SocialData API to convert a Twitter/X handle into the user ID.
- Followers Retrieval: Our loop will keep grabbing pages until there’s no more left—no data left behind.
- Output Handling: Choose between JSON and CSV depending on what you want to do with the data.
Step 6: Chill/Test Mode
Use test mode if you’re short on time or just want to give it a quick spin without hammering the API—perfect for those quick “Is it working?” moments.
Wrapping Up
Boom, there you have it! Loftwah’s custom script to collect Twitter/X followers data. We’ve covered JSON and CSV output, command-line args, pagination, and more. Feel free to make it your own, remix it, add your flair, or automate it into a bigger workflow.
If you get stuck or want to build on it, just holler. Happy follower-fetching, and keep it legendary!