/SOC-Parser

Parses UC San Diego's schedule of classes. Mostly PEP8-compliant and Python 2.6+ & 3.0+ compatible.

Primary LanguagePythonApache License 2.0Apache-2.0

SOC Parser

Parses the schedule of classes. The program is extensible and has few functions. It can scrape data from any quarter specified and all or specific subjects. Also recently implemented is tracking on a per-class level. This program was built using Python and is compatible with Python 2.6+ and Python 3.0+ 🐍. It also is mostly PEP8 compliant and has generous notes on functionality. Data is uploaded to firebase but can be swapped for another one.

How to use (Mac) 💻

There are a couple of python modules you must install first to run this program.

NOTE: If pip is already installed, proceed to step 3.

  1. Install homebrew. This is a useful general package manager for macOS.
  2. Install Python via homebrew - brew install python.
  3. Install lxml - pip install lxml.
  4. Install requests - pip install requests.
  5. Install bs4 - pip install bs4.
  6. Install cachecontrol - pip install cachecontrol.
  7. Install firebase - pip install python-firebase.
  8. (OPTIONAL) Python 3 setup: Install Python 3 via homebrew - brew install python3. Then, repeat steps 3-7 with pip3 instead of pip.

Improvements to do 🔧

  • Account for multiple teachers, sections, emails, and more.
  • Fix db schema to be more flat for efficient querying. Put everything in the header on the first level.
  • setup is where we have granular control over the subjects and quarter to be parsed. Combine this with a command line interface and knowledge of when the course data was last updated. This allows us to update the data stored in firebase faster as we would parse less.

TIPS

  • You can delete an entire firebase project and start from scratch.
  • You can edit the files in Atom / Sublime Text 3 and open the directory containing the files in the terminal window using a keyboard shortcut (needs a package for both).

Brief Explanations 🔍

  • get_quarters: Retrieves all the quarters from the drop-down menu shown here. For now, this function only retrieves quarters from the current and following year. This can be changed by altering VALID_YEARS.
  • get_subjects: Retrieves all the subjects from the multi-select menu shown here. It does this by parsing this page which includes all the subjects shown in the multi-select menu.
  • setup: This function does three things. First, it updates the post request with data gathered from get_quarters. Second, it updates the post request with data gathered from get_subjects. Finally, we submit the post request and identify the number of pages to parse (NUMBER_PAGES). We return the quarter we are parsing so we can print it out later.
  • get_data: Retrieves all the data from each page we will parse. It accepts a generator, url_page_tuple, which generates a tuple (page url, page number) for each page to parse. We parse each page, appending the data to the list master, and then returning master upon completion. This function's only gets all of the data. It does not parse any data gathered into separate values.
  • check_collision: Checks the parsed data for any duplicate keys. As keys uniquely identify classes, we must ensure all keys are unique. If there are duplicate keys, this function prints out each of the duplicates so we can isolate the problem.
  • TODO