VOOZH about

URL: https://apify.com/goat255/instagram-stories-highlights-scraper

โ‡ฑ ๐Ÿ“ธ Instagram Stories Scraper - Download Stories & Highlights ยท Apify


๐Ÿ‘ Instagram Stories & Highlights Scraper avatar

Instagram Stories & Highlights Scraper

Pricing

from $5.00 / 1,000 users

Go to Apify Store

Instagram Stories & Highlights Scraper

Scrape current Instagram stories (24h tray) and all permanent highlight reels with inner items from any public profile. Get original-resolution media URLs, expirations, music, stickers, captions. No Instagram API key, no login.

Pricing

from $5.00 / 1,000 users

Rating

0.0

(0)

Developer

๐Ÿ‘ Goutam Soni

Goutam Soni

Maintained by Community

Actor stats

1

Bookmarked

62

Total users

41

Monthly active users

24 hours

Issues response

2 hours ago

Last modified

Share

Instagram Stories & Highlights Scraper Goat - Download Stories, Highlight Reels & Inner Items

Scrape current Instagram stories (24h tray) and all permanent highlight reels with their inner items from any public Instagram profile. Bulk download story media URLs, expiration timestamps, music, stickers, captions, and full highlight content - without an Instagram login, cookies, or API key.

What this Instagram Stories scraper does

For each username you pass in, the actor resolves the numeric Instagram user ID, then fetches:

  • Current Instagram stories - every item in the active 24-hour story tray (images and videos).
  • Highlight reels - every saved highlight on the profile with cover image, title, item count, and creation timestamp.
  • Highlight items (optional) - every photo and video inside each highlight, expanded one request per highlight.

Returns clean ordered JSON with original-resolution media URLs, dimensions, expirations, accessibility captions, music, stickers, and links. Multi-source failover and residential proxies keep success rates high.

Perfect for story archiving, highlight repurposing, brand monitoring, and content auditing on Instagram.

Why use this Instagram Stories scraper

  • No login, no cookies, no API key - works on every public Instagram account.
  • Stories AND highlights in one pass - many scrapers do only one or the other.
  • Highlight expansion - get every photo/video inside every saved highlight (not just the cover).
  • Original-resolution media URLs - 1080-wide images and full-quality video.
  • Multi-source failover - upstream rate-limited? The actor falls back automatically.
  • Residential proxies built in.
  • Beat the 24-hour clock - archive stories before they expire.
  • One flat charge per profile - all stories and highlights for a username are covered by a single charge. You are never billed per-item or for an empty "no story" response.

What data you get per username

{
"username":"example_user",
"userId":"000000000",
"status":"ok",
"isPrivate":false,
"isAccessible":true,
"errorMessage":null,
"resolveReason":null,
"storyCount":4,
"highlightCount":28,
"stories":[
{
"id":"...",
"mediaType":"video",
"takenAt":1714032018,
"expiringAt":1714118418,
"imageUrl":"https://...",
"videoUrl":"https://...",
"originalWidth":1080,
"originalHeight":1920,
"accessibilityCaption":"..."
}
],
"highlights":[
{
"highlightId":"highlight:17876...",
"title":"Wildlife",
"mediaCount":12,
"coverImageUrl":"https://...",
"items":[/* same shape as a story item */]
}
]
}

Per-username status fields

Every result carries an explicit status so you can tell an empty story tray apart from a private, missing, or unreachable account, instead of guessing from storyCount: 0.

FieldTypeDescription
statusstringOne of ok, no_active_stories, private, not_found, fetch_failed
isPrivateboolean / nulltrue for private accounts, false for public, null when the account could not be resolved
isAccessiblebooleantrue when public media could be read, false for private / not-found / failed
errorMessagestring / nullHuman-readable reason when isAccessible is false, otherwise null
resolveReasonstring / nullMachine-readable hint for the resolution stage: account_not_found, user_id_not_resolved, or unreachable. null when the account resolved cleanly

Status meanings:

  • ok - public account, at least one active story (or stories were not requested).
  • no_active_stories - public, accessible account whose 24h story tray is currently empty. Highlights may still be present.
  • private - private account. Stories and highlights are not publicly accessible.
  • not_found - the lookup positively confirmed the username does not resolve to a real Instagram account (resolveReason: account_not_found). This is a permanent result, safe to treat as gone.
  • fetch_failed - the account could not be resolved or reached on this run for a transient reason such as a block or rate limit (resolveReason: user_id_not_resolved or unreachable). This is retryable, so a handle that exists will resolve on a later run rather than being reported as missing.

Run summary record

The last item in the dataset is a single run-level summary describing what happened to the whole input list (deduplication, skipped invalid inputs, and totals). It is tagged recordType: "runSummary" so you can filter it out of the per-username rows.

{
"recordType":"runSummary",
"summary":{
"inputCount":10,
"uniqueUsernameCount":7,
"processedCount":7,
"skippedCount":2,
"duplicateCount":1
},
"skippedInputs":[
{"input":"https://instagram.com/","reason":"invalid_input"}
],
"duplicates":[
{"input":"example_user","normalizedUsername":"example_user","reason":"duplicate"}
]
}

How to use the Instagram Stories Scraper

  1. Click Try for free on the actor page.
  2. Enter Instagram usernames in the usernames input (URLs, @handles, or plain usernames - all accepted).
  3. Toggle what to fetch:
    • includeStories - the 24-hour story tray (default on)
    • includeHighlights - the list of highlight reels (default on)
    • expandHighlightItems - inner items in each highlight (default on)
  4. Set maxHighlightsPerUser to cap how many highlights to expand (0 = unlimited).
  5. Tune concurrency (default 4) and delayBetweenRequests (default 1s).
  6. Click Save & start. Download JSON / CSV / Excel / XML / HTML.

Input parameters

FieldTypeDefaultDescription
usernamesstring[]-Usernames, @handles, or full Instagram URLs (mix freely, auto-deduped)
includeStoriesbooleantrueFetch the current 24h Instagram story tray
includeHighlightsbooleantrueFetch the list of highlight reels
expandHighlightItemsbooleantrueFetch the inner items inside each highlight
maxHighlightsPerUserinteger0Cap how many highlights to expand (0 = unlimited)
compactOutputbooleanfalseDrop empty collections from each result (e.g. omit highlights and highlightCount on a stories-only run) for a leaner dataset
concurrencyinteger4Usernames processed in parallel
delayBetweenRequestsnumber1.0Seconds between requests inside one username pipeline
proxyConfigurationobjectresidentialApify proxy settings (residential required)

Top use cases

  • Story archiving - capture competitors' stories before the 24-hour expiration deletes them.
  • Highlight repurposing - bulk-pull every highlight from a brand to remix into Reels or carousels.
  • Brand monitoring - daily snapshot of what creators are posting in their stories.
  • Content audits - full inventory of a profile's saved highlights with cover images.
  • OSINT and investigations - extract media from public stories with timestamps and expiration data.
  • Influencer agency vetting - check how active a creator is by scraping recent story counts.

Integrations

Apify API

$curl"https://api.apify.com/v2/datasets/{DATASET_ID}/items?format=json"

Python

from apify_client import ApifyClient
client = ApifyClient("YOUR_API_TOKEN")
run = client.actor("goat255/instagram-stories-highlights-scraper").call(run_input={
"usernames":["example_user_1","example_user_2"],
"includeStories":True,
"includeHighlights":True,
"expandHighlightItems":True,
})
for item in client.dataset(run["defaultDatasetId"]).iterate_items():
print(f"@{item['username']}: {item['storyCount']} stories, {item['highlightCount']} highlights")

No-code integrations

Send results directly to Google Sheets, Slack, Zapier, Make, Amazon S3, or your own webhook via Apify Integrations.

Pricing

Pay-per-event. One charge per username scraped covers all stories + highlights for that user.

EventPrice (tiered by Apify plan)
User scraped (primary)$0.005 - $0.007

Apify subscription tiers (Bronze through Diamond) pay less per user. Apify's $5 platform free credit applies on first use.

FAQ

Do I need an Instagram account or API key?

No. The scraper works on every public Instagram profile without auth.

How long do Instagram stories last?

24 hours. After that they're gone unless saved to a highlight. This scraper captures them before they expire.

Can it download Instagram highlights?

Yes - every saved highlight on the profile, with cover image, title, and (optionally) every photo/video inside.

Can it scrape private Instagram accounts' stories?

No. Only public accounts are accessible. Private accounts return zero stories.

Will Instagram block this?

Multi-source failover plus rotating residential proxies handle Instagram's rate limits automatically.

How do I download the media files?

The actor returns imageUrl / videoUrl for every story and highlight item. Pipe those URLs to your own downloader, S3, or webhook.

How fast is it?

~15-20 seconds per profile with full highlight expansion (depending on how many highlights). Disable expandHighlightItems for a 5x speedup if you only need the highlight list.

Related Apify actors

Support

Open an issue on the actor page if something breaks or a field's missing. Reviews are read and replied to.

You might also like

Instagram Stories Scraper โ€” Stories & Highlights Metadata

automation-lab/instagram-stories-scraper

Scrape current Instagram stories and highlight reels from public profiles. Extract media URLs, timestamps, captions, stickers, music, links, highlight titles, and optional profile metadata; supports batch usernames.

๐Ÿ‘ User avatar

Stas Persiianenko

102

4.0

Instagram Highlight Stories Scraper

igview-owner/instagram-highlights-stories-viewer

Extract all stories from Instagram Highlights instantly. Get images, videos, and metadata using just the Highlight ID. No login required. Fast & reliable.

๐Ÿ‘ User avatar

Sachin Kumar Yadav

188

5.0

Instagram Media & Profile Scraper

endspec/instagram-instant-media-scraper

Scrape Instagram profile data: reels, posts, stories, highlights, follower counts, engagement.

Instagram Highlights Scraper

api-empire/instagram-highlights-scraper

Instagram Highlights Scraper captures all Highlight stories from any public profile. Extract media URLs, captions, timestamps, views, and metadata. Ideal for research, content auditing, brand analysis, and workflows that need organized Instagram Highlights data.

Instagram Highlights Scraper

scrapapi/instagram-highlights-scraper

Extract Instagram Highlights data from public profiles with this scraper. Collect highlight titles, story media URLs, timestamps, captions, and profile details. Useful for brand research, influencer analysis, content monitoring, and tracking stories saved in Instagram Highlights.

Instagram Highlights Scraper

seemuapps/instagram-highlights-scraper

Fetch Instagram highlights and their stories for any public profile.

Instagram Highlights Scraper

scrapier/instagram-highlights-scraper

Scrape Instagram Story Highlights with the Instagram Highlights Scraper. Extract highlight titles, cover images, stories, video URLs, captions, and timestamps. Perfect for content analysis, trend tracking, and competitor research. Fast, accurate, and scalable for any profile.

Instagram Stories Scraper

nifty.codes/instagram-stories-scraper

Extract Instagram stories including media URLs, expiration dates, and author metadata. Powered by Instagram Scraper.