From notes
what to do if data is not checked, just say it is not present on the website for the remaining fill ins and explain as the report detail Test actor run https://console.apify.com/organization/5SDPsAprw8Nd4xyeT/actors/shu8hvrXbJbY3Eb9W
How this scraper works: This scraper will take data from salesforce and update whether Merchant Instagram's have LinkTrees, pay links on those link trees, pay links on the instragrsm page, and if the pay link is present on the merchants website
Inputs directly into the scraper: Takes the Account ID Takes the Account Name Takes correct Instagram URLs (https://instagram/username and NOT @username or user name) Takes correctly filled out site URLs
Possible outputs/how to interperate:
Take Insta Validator, Linktree validator, and website validator to make the csv for return when done
- Use columns: ID, Name, Instagram link, Website, (Added fields from apify: Linktree present (linktree will be added there), Instagram Pay Link Present (Will be null if not found on profile or the actual linktree), and Website Pay Link Present
If all three extra fields are filled out (Linktree present (url output), Instagram Pay Link Present, Website Pay Link Present) they are in compliance. If the Linktree is present but the pay link is not present that means it is not present on the linktree if the linktree is not present but the instagram pay link is present, that means pay.withcherry.com is in the bio and you may decide to have them change to linktree. If the website and instagram profile were not filled out properly by the merchant or intake rep, it will show it as not installed. If they do not have an instagram it will show up as not installed on instagram or linktree. If they do not have a website, it will show up as not installed on their website.
How it reads websites: It looks for any pay.withcherry.com link first, then looks for the text "payment plans" with an html embed of the widget's id="all" plus the pay.withcherry.com link, then it looks for the text "payment plans" with an iframe without cherry mentioned at all as a last resort.
How deep does it go? It visits and checks every link present on the first URL's page you provide. It will not look further than that as most marketing checks require it to be on just one other tab and not super hidden, else we need to reach out and get that fixed for the merchant. This is known as depth of 1.
How it reads instagrams: It grabs the instagram user link and tries to test to see if the profile exists, if there is not a url present that is proper such as a username with spaces or @username, it will return false and not run the linktree check. Then it looks for any link in the bio that is pay.withcherry.com or a linktree, milkshake (or whatever you wish to add to the list in the scraper my-actor-1 around line 318 const sites)
How it reads linktrees/added link services: Grabs the link service and scrapes one page really fast looking for an href pay.withcherry.com present anywhere on the page.
How this can be modified later: In the webscraper - you can check if text or verbage is present in html and return potentially the page it was on or how deep it was using apify docs. You can search for the text and add a salesforce field to see what text was present in the linktree for the href by grabbing it. The possibilities are endless for jquery.
Why we chose to do a manual package
progress waiting git then set settings from https://github.com/gippy/instagram-scraper#input-parameters
upload the app test that then figure out how to take data from salesforce or snowflake, and then give it to apify then take that and put it back set or create record hopefully lets you innput data to run task from there
if something breaks in this https://github.com/zpelechova/instagram-miniactors/tree/main/instagram-profile
refer to this
https://github.com/gippy/instagram-scraper#input-parameters
check modifying the packages ability because, maintenance-wise, if its an apify package it should run until someone updates something in the primary package, which would most likely require someone edit the 45 lines of code thats porting it with the params here in https://github.com/zpelechova/instagram-miniactors/blob/main/instagram-profile/main.js
Our free Instagram Profile Scraper allows you to scrape profile information from Instagram. Just add one or more Instagram usernames to get all profile data.
Scraping Instagram profiles just means that you're collecting publicly available data on Instagram users.
This data can give you valuable information about popular users anywhere in the world, help you predict trends, track brand awareness, learn how to improve your Instagram performance, or just keep an eye on competing influencers.
If you want more ideas, check out our industries pages for ways web scraping is already being used in a wide range of companies.
Instagram Profile Scraper is designed to be fast and easy to use so there aren't too many parameters or settings.
- Create a free Apify account.
- Open Instagram Profile Scraper
- Add one or more Instagram usernames to scrape.
- Click run and wait for the datasets to be extracted.
- Download your data in JSON, XML, CSV, Excel, or HTML.
Use our super fast and easy dedicated scrapers if you want to scrape specific Instagram data. Fewer settings to change and faster results. Just enter one or more Instagram usernames or URLs and click to scrape.
Our Instagram scrapers are ethical and do not extract any private user data, such as email addresses, gender, or location. They only extract what the user has chosen to share publicly. We therefore believe that our scrapers, when used for ethical purposes by Apify users, are safe. However, you should be aware that your results could contain personal data. Personal data is protected by the GDPR in the European Union and by other regulations around the world. You should not scrape personal data unless you have a legitimate reason to do so. If you're unsure whether your reason is legitimate, consult your lawyers. You can also read our blog post on the legality of web scraping.
Try our more advanced Instagram Scraper if you need more options and are comfortable with changing settings.
Let us know if you need a custom Instagram scraping solution.
There are two main factors to take into account if you want to run one of our Instagram scrapers on the Apify platform:
- Compute units - used for running the scraper
- Residential proxy traffic - needed to access Instagram without login
Instagram now aggressively blocks scrapers and redirects them to a login page. The only reliable solution to this problem is to use residential proxies. Datacenter proxies only work in rare cases.
Instagram scraper is free to use, although you will need to use residential proxies on Apify Proxy if you run it on the Apify platform. This is because Instagram changed the rules in 2021 and now you always need to use a residential proxy for scraping. Luckily, every new Apify account includes a small free trial of residential proxies, so you should be able to test any of our Instagram scrapers.
You can also use proxies from other providers in the custom proxies fields (proxyUrls
in the JSON settings).
Scraping 1,000 Instagram profiles will cost you just $5.50 platform credits from your Apify subscription plan.
Scraping 1,000 profiles requires about:
- 10 compute units
- 0.24 GB of proxy traffic
Based on Apify's pricing at the time of writing, scraping 1,000 profiles would cost 10 CU * $0.25 + 0.24 GB * 12.5 GB, which is a total of $5.50. The Apify Personal plan ($49) would allow you to scrape about 9,000 Instagram profiles monthly.
The Apify platform provides residential proxies if you have a paid subscription. These proxies are only available to be run within actors on the Apify platform, not externally. If you are interested in using residential proxies for this scraper, contact support@apify.com
via email or in-app chat to get the proxies enabled.
The input of this scraper should be JSON containing the Instagram username or usernames to be scraped. Required fields are:
Field | Type | Description |
---|---|---|
username | Array | (required) Username to scrape posts from |
{
"username": ["apifytech"],
}