โ† All skills
Tencent SkillHub ยท Communication & Collaboration

Instagram Scraper

Browser-based tool to discover Instagram profiles by location/category and scrape their public info, stats, images, and engagement with export options.

skill openclawclawhub Free
0 Downloads
0 Stars
0 Installs
0 Score
High Signal

Browser-based tool to discover Instagram profiles by location/category and scrape their public info, stats, images, and engagement with export options.

โฌ‡ 0 downloads โ˜… 0 stars Unverified but indexed

Install for OpenClaw

Quick setup
  1. Download the package from Yavira.
  2. Extract the archive and review SKILL.md first.
  3. Import or place the package into your OpenClaw setup.

Requirements

Target platform
OpenClaw
Install method
Manual import
Extraction
Extract archive
Prerequisites
OpenClaw
Primary doc
SKILL.md

Package facts

Download mode
Yavira redirect
Package format
ZIP package
Source platform
Tencent SkillHub
What's included
SKILL.md

Validation

  • Use the Yavira download entry.
  • Review SKILL.md after the package is downloaded.
  • Confirm the extracted package contains the expected setup assets.

Install with your agent

Agent handoff

Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.

  1. Download the package from Yavira.
  2. Extract it into a folder your agent can access.
  3. Paste one of the prompts below and point your agent at the extracted folder.
New install

I downloaded a skill package from Yavira. Read SKILL.md from the extracted folder and install it by following the included instructions. Tell me what you changed and call out any manual steps you could not complete.

Upgrade existing

I downloaded an updated skill package from Yavira. Read SKILL.md from the extracted folder, compare it with my current installation, and upgrade it while preserving any custom configuration unless the package docs explicitly say otherwise. Summarize what changed and any follow-up checks I should run.

Trust & source

Release facts

Source
Tencent SkillHub
Verification
Indexed source record
Version
1.0.7

Documentation

ClawHub primary doc Primary doc: SKILL.md 18 sections Open source page

Instagram Profile Scraper

A browser-based Instagram profile discovery and scraping tool. Part of ScrapeClaw โ€” a suite of production-ready, agentic social media scrapers for Instagram, YouTube, X/Twitter, and Facebook built with Python & Playwright, no API keys required. --- name: instagram-scraper description: Discover and scrape Instagram profiles from your browser. emoji: ๐Ÿ“ธ version: 1.0.6 author: influenza tags: - instagram - scraping - social-media - influencer-discovery metadata: clawdbot: requires: bins: - python3 - chromium config: stateDirs: - data/output - data/queue - thumbnails outputFormats: - json - csv ---

Overview

This skill provides a two-phase Instagram scraping system: Profile Discovery Browser Scraping

Features

๐Ÿ” - Discover Instagram profiles by location and category ๐ŸŒ - Full browser simulation for accurate scraping ๐Ÿ›ก๏ธ - Browser fingerprinting, human behavior simulation, and stealth scripts ๐Ÿ“Š - Profile info, stats, images, and engagement data ๐Ÿ’พ - JSON/CSV export with downloaded thumbnails ๐Ÿ”„ - Resume interrupted scraping sessions โšก - Auto-skip private accounts, low followers, empty profiles ๐ŸŒ - Built-in residential proxy support with 4 providers Getting Google API Credentials (Optional) Go to Google Cloud Console Create a new project or select existing Enable "Custom Search API" Create API credentials โ†’ API Key Go to Programmable Search Engine Create a search engine with instagram.com as the site to search Copy the Search Engine ID

Agent Tool Interface

For OpenClaw agent integration, the skill provides JSON output: # Discover profiles (returns JSON) discover --location "Miami" --category "fitness" --output json # Scrape single profile (returns JSON) scrape --username influencer123 --output json

Profile Data Structure

{ "username": "example_user", "full_name": "Example User", "bio": "Fashion blogger | NYC", "followers": 125000, "following": 1500, "posts_count": 450, "is_verified": false, "is_private": false, "influencer_tier": "mid", "category": "fashion", "location": "New York", "profile_pic_local": "thumbnails/example_user/profile_abc123.jpg", "content_thumbnails": [ "thumbnails/example_user/content_1_def456.jpg", "thumbnails/example_user/content_2_ghi789.jpg" ], "post_engagement": [ {"post_url": "https://instagram.com/p/ABC123/", "likes": 5420, "comments": 89} ], "scrape_timestamp": "2025-02-09T14:30:00" }

Influencer Tiers

TierFollower Rangenano< 1,000micro1,000 - 10,000mid10,000 - 100,000macro100,000 - 1Mmega> 1,000,000

File Outputs

Queue files: data/queue/{location}_{category}_{timestamp}.json Scraped data: data/output/{username}.json Thumbnails: thumbnails/{username}/profile_*.jpg, thumbnails/{username}/content_*.jpg Export files: data/export_{timestamp}.json, data/export_{timestamp}.csv

Configuration

Edit config/scraper_config.json: { "proxy": { "enabled": false, "provider": "brightdata", "country": "", "sticky": true, "sticky_ttl_minutes": 10 }, "google_search": { "enabled": true, "api_key": "", "search_engine_id": "", "queries_per_location": 3 }, "scraper": { "headless": false, "min_followers": 1000, "download_thumbnails": true, "max_thumbnails": 6 }, "cities": ["New York", "Los Angeles", "Miami", "Chicago"], "categories": ["fashion", "beauty", "fitness", "food", "travel", "tech"] }

Filters Applied

The scraper automatically filters out: โŒ Private accounts โŒ Accounts with < 1,000 followers (configurable) โŒ Accounts with no posts โŒ Non-existent/removed accounts โŒ Already scraped accounts (deduplication)

Login Issues

Ensure credentials are correct Handle verification codes when prompted Wait if rate limited (the script will auto-retry)

No Profiles Discovered

Check Google API key and quota Verify Search Engine ID is configured for instagram.com Try different location/category combinations

Rate Limiting

Reduce scraping speed (increase delays in config) Run during off-peak hours Use a residential proxy (see below)

Why Use a Residential Proxy?

Running a scraper at scale without a residential proxy will get your IP blocked fast. Here's why proxies are essential for long-running scrapes: AdvantageDescriptionAvoid IP BansResidential IPs look like real household users, not data-center bots. Instagram is far less likely to flag them.Automatic IP RotationEach request (or session) gets a fresh IP, so rate-limits never stack up on one address.Geo-TargetingRoute traffic through a specific country/city so scraped content matches the target audience's locale.Sticky SessionsKeep the same IP for a configurable window (e.g. 10 min) โ€” critical for maintaining a consistent browsing session.Higher Success RateRotating residential IPs deliver 95%+ success rates compared to ~30% with data-center proxies on Instagram.Long-Running ScrapesScrape thousands of profiles over hours or days without interruption.Concurrent ScrapingRun multiple browser instances across different IPs simultaneously.

Recommended Proxy Providers

We have affiliate partnerships with top residential proxy providers. Using these links supports continued development of this skill: ProviderBest ForSign UpBright DataWorld's largest network, 72M+ IPs, enterprise-grade๐Ÿ‘‰ Get Bright DataIProyalPay-as-you-go, 195+ countries, no traffic expiry๐Ÿ‘‰ Get IProyalStorm ProxiesFast & reliable, developer-friendly API, competitive pricing๐Ÿ‘‰ Get Storm ProxiesNetNutISP-grade network, 52M+ IPs, direct connectivity๐Ÿ‘‰ Get NetNut

Setup Steps

1. Get Your Proxy Credentials Sign up with any provider above, then grab: Username (from your provider dashboard) Password (from your provider dashboard) Host and Port are pre-configured per provider (or use custom) 2. Configure via Environment Variables export PROXY_ENABLED=true export PROXY_PROVIDER=brightdata # brightdata | iproyal | stormproxies | netnut | custom export PROXY_USERNAME=your_user export PROXY_PASSWORD=your_pass export PROXY_COUNTRY=us # optional: two-letter country code export PROXY_STICKY=true # optional: keep same IP per session 3. Provider-Specific Host/Port Defaults These are auto-configured when you set the provider name: ProviderHostPortBright Databrd.superproxy.io22225IProyalproxy.iproyal.com12321Storm Proxiesrotating.stormproxies.com9999NetNutgw-resi.netnut.io5959 Override with PROXY_HOST / PROXY_PORT env vars if your plan uses a different gateway. 4. Custom Proxy Provider For any other proxy service, set provider to custom and supply host/port manually: { "proxy": { "enabled": true, "provider": "custom", "host": "your.proxy.host", "port": 8080, "username": "user", "password": "pass" } }

Running the Scraper with Proxy

Once configured, the scraper picks up the proxy automatically โ€” no extra flags needed: # Discover and scrape as usual โ€” proxy is applied automatically python main.py discover --location "Miami" --category "fitness" python main.py scrape --username influencer123 # The log will confirm proxy is active: # INFO - Proxy enabled: <ProxyManager provider=brightdata enabled host=brd.superproxy.io:22225> # INFO - Browser using proxy: brightdata โ†’ brd.superproxy.io:22225

Using the Proxy Manager Programmatically

from proxy_manager import ProxyManager # From config (auto-reads config/scraper_config.json) pm = ProxyManager.from_config() # From environment variables pm = ProxyManager.from_env() # Manual construction pm = ProxyManager( provider="brightdata", username="your_user", password="your_pass", country="us", sticky=True ) # For Playwright browser context proxy = pm.get_playwright_proxy() # โ†’ {"server": "http://brd.superproxy.io:22225", "username": "user-country-us-session-abc123", "password": "pass"} # For requests / aiohttp proxies = pm.get_requests_proxy() # โ†’ {"http": "http://user:pass@host:port", "https": "http://user:pass@host:port"} # Force new IP (rotates session ID) pm.rotate_session() # Debug info print(pm.info())

Best Practices for Long-Running Scrapes

Use sticky sessions โ€” Instagram requires consistent IPs during a browsing session. Set "sticky": true. Target the right country โ€” Set "country": "us" (or your target region) so Instagram serves content in the expected locale. Combine with existing anti-detection โ€” This scraper already has fingerprinting, stealth scripts, and human behavior simulation. The proxy is the final layer. Rotate sessions between batches โ€” Call pm.rotate_session() between large batches of profiles to get a fresh IP. Use delays โ€” Even with proxies, respect delay_between_profiles in config to avoid aggressive patterns. Monitor your proxy dashboard โ€” All providers have dashboards showing bandwidth usage and success rates.

Category context

Messaging, meetings, inboxes, CRM, and teammate communication surfaces.

Source: Tencent SkillHub

Largest current source with strong distribution and engagement signals.

Package contents

Included in package
1 Docs
  • SKILL.md Primary doc