This scraper is provided as a public service because Glasdoor doesn't have an API for reviews. Glassdoor TOS prohibit scraping and I make no representation that your account won't be banned if you use this program. Furthermore, should I be contacted by Glassdoor with a request to remove this repo, I will do so immediately.
Have you ever wanted to scrape reviews from Glassdoor, but bemoaned the site's lack of a public API for reviews? Worry no more! This script will go through pages and pages of reviews and scrape review data into a tidy CSV file. Pass it a company page and set a limit to scrape the 25 most conveniently available reviews, or control options like the number of reviews to scrape and the max/min review publication date.
It takes about 1.5 seconds per review to scrape. So it will take about 25 minutes to scrape 1,000 reviews, or a little over 4 hours to scrape 10,000 reviews. This script requires patience. 😁
First, make sure that you're using Python 3.
- Clone or download this repository.
- Run
pip install -r requirements.txt
inside this repo. Consider doing this inside of a Python virtual environment. - Install Chromedriver in the working directory.
- Create a
secret.json
file containing the keysusername
andpassword
with your Glassdoor login information, or pass those arguments at the command line. Note that the second method is less secure, but in any case you should consider creating a dummy Glassdoor account.
usage: main.py [-h] [-u URL] [-f FILE] [--headless] [--username USERNAME]
[-p PASSWORD] [-c CREDENTIALS] [-l LIMIT] [--start_from_url]
[--max_date MAX_DATE] [--min_date MIN_DATE]
optional arguments:
-h, --help show this help message and exit
-u URL, --url URL URL of the company's Glassdoor landing page.
-f FILE, --file FILE Output file.
--headless Run Chrome in headless mode.
--username USERNAME Email address used to sign in to GD.
-p PASSWORD, --password PASSWORD Password to sign in to GD.
-c CREDENTIALS, --credentials CREDENTIALS Credentials file
-l LIMIT, --limit LIMIT Max reviews to scrape
--start_from_url Start scraping from the passed URL.
--max_date MAX_DATE Latest review date to scrape. Only use this option
with --start_from_url. You also must have sorted
Glassdoor reviews ASCENDING by date.
--min_date MIN_DATE Earliest review date to scrape. Only use this option
with --start_from_url. You also must have sorted
Glassdoor reviews DESCENDING by date.
Run the script as follows, taking Wells Fargo as an example. You can pass --headless
to prevent the Chrome window from being visible, and the --limit
option will limit how many reviews get scraped. The-f
option specifies the output file, which defaults to glassdoor_reviews.csv
.
Suppose you want to get the top 1,000 most popular reviews for Wells Fargo. Run the command as follows:
python main.py --headless --url "https://www.glassdoor.com/Overview/Working-at-Wells-Fargo-EI_IE8876.11,22.htm" --limit 1000 -f wells_fargo_reviews.csv
Note: To be safe, always surround the URL with quotes. This only matters in the presence of a query string.
If you want to scrape all reviews in a date range, sort reviews on Glassdoor ascending/descending by date, find the page with the appropriate starting date, set the max/min date to the other end of your desired time range, and set limit to 99999.
Suppose you want to scrape all reviews from McDonald's that were posted in 2010:
- Navigate to McDonald's Glassdoor page and sort reviews ascending by date.
- Find the first page with a review from 2010, which happens to be page 13.
- Send the command to the script:
python main.py --headless --start_from_url --limit 9999 --max_date 2010-12-31 --url "https://www.glassdoor.com/Reviews/McDonald-s-Reviews-E432_P13.htm?sort.sortType=RD&sort.ascending=true"
If there's demand for it, we can automate this process to provide a simple interface for filtering by date.
Below are a list of updates that were made after forking the original repository. The commits timeline can be referenced for further details.
Any pull requests that are merged into the original repository will be removed from the below list
- Updated scrape_years function since it was throwing an error, due to change in XPATH location.
- Updated scrape_pros, scrape_cons, and scrape_advice to use updated class name.
- Fixed counting issue between res and arg.limits.
- res was zero indexed; added 1 to count in where condition of main()
- arg.limits is indexed starting 1
- scrape_helpful was returning 0 from the except clause for all reviews. Used a text.replace to make the text scrape functional.
- After fix, scrape_helpful returns the number of times the review was voted as helpful
New python script to facilitate running main.py for scraping multiple companies on glassdoor. Since 1000 reviews can take about 25 minutes, you may not want to come back every 25 minutes and rerun main.py for the next company. In fact, if you were running a scrape for a different number of reviews for each company, then the time interval to check and run the next itteration of main.py becomes sporatic. multiscrape.py is desigedn to work just like the Ronco Rotisserie Oven ... "Just set it and forget it."
multiscrape contains a list of tuples called pages
. Each tuple represents a company whose reviews are to be scraped by main.py. There are 3 elements in each tuple, each of which is a string, that represent an input to be passed to the command line entry to run main.py. Items in the tuple are as follows:
- Item 1: url (company overview page obtained by searching glassdoor.com)
- Item 2: limit
- Item 3: output file name (.csv not used)
Future updates of multiscrape.py may contain other inputs.
Inorder to use multiscrape.py open it in a text editor and update the tuples in the pages
list so that each tuple corresponds to the .
For example, say you want to scrape the first 1000 reviews from each of Albertson's, Wal-mart, and Target. you would simply update pages
to the following:
pages = [
('"https://www.glassdoor.com/Overview/Working-at-Albertsons-Companies-EI_IE22.11,31.htm"', "1000", "albertsons"),
('"https://www.glassdoor.com/Overview/Working-at-Walmart-EI_IE715.11,18.htm"', "1000", "walmart"),
('"https://www.glassdoor.com/Overview/Working-at-Target-EI_IE194.11,17.htm"', "1000", "target")
]