Skip to content

Hosting all of the code for scraping websites for the Harvard Open Data Project.

Notifications You must be signed in to change notification settings

wzhang2022/HODP-Scraping

 
 

Repository files navigation

Harvard Open Data Project Scrapers

A basic repo for all of the automated HODP scraping scripts

Contributing

Please refer to CONTRIBUTING.md for instructions on how to add your own scraper.

Deploying

  1. If you have access, ssh into the instance, and run sudo su to login again as the root user.
  2. Navigate to the project and run
source hodp/bin/activate
./resolve_reqs
./init_crontab
crontab scrape.tab

TODOs

  • Add logging system
  • Add unit tests

Changelog

  • 05/25/19 #2 (kevalii)
    • Reverted the routing referenced in #1
    • Added init_crontab.sh, write_cron.py, and resolve_reqs.py.
      • write_cron.py writes cron jobs to a crontab (scrape.tab) using an API provided by python-crontab package. You can still write cron jobs directly into scrape.tab; this just provides a perhaps more organized way of writing cron jobs in.
        • NOTE: scrape.tab isn't provided in the repo. Either touch it locally or execute init_crontab.sh
      • init_crontab.sh executes write_cron.py but it does not set the crontab. Make any changes to scrape.tab and then execute crontab scrape.tab.
      • resolve_reqs.py goes through all the requirements.txts in each subdirectory of scrapers/ and installs the dependencies, updating the root directory's requirements.txt as well.
    • scrapers/crime/scrape_crime.py no longer features the scrape function referenced in #1.
  • 05/25/19 #1 (kevalii)
    • Set up routing, enabling us to add more scrapers (and schedule them) in a sustainable manner.
    • Added gocrimson scraper at /scrape/gocrimson and a corresponding cron job.
      • While the scraper has also been added to this repo, it is actually executed by an GCloud function that uses a local copy of the source code for the scraper. For the future, we'll have to adjust this so that the function is sourced from this repo instead.
    • Modified crime scraper to route to /scrape/crime.
      • Wrapped relevant code in a scrape function in the renamed src file scrape_crime.py so that the scraper is executed by a call to scrape instead of just running at the top-level.
    • Moved to each scraper to a respective folder in scrapers/ that also contains each scraper's respective dependencies in a requirements.txt.

About

Hosting all of the code for scraping websites for the Harvard Open Data Project.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 98.8%
  • Shell 1.2%