Skip to main content

Utility to average gradescope csv output to final grades

Project description

Gradescope Mean

A utility which computes final grades (example: grade_full.csv) from gradescope outputs. It allows the instructor to ...

  • weight assignments per category
    • e.g. all HW assignments are 50% of grade
  • waive lowest N assignments per category
    • e.g. 2 lowest HW assignments, per student, are waived
  • apply a late penalty (per day) that assignments are submitted beyond deadline
    • e.g. HW is penalized 15% of average assignment hw weight for every day late it is submitted
    • also includes support for not penalizing the first N "late days" per assignment category (e.g. each student may use up to 3 "late days" across all HWs without penalty)
  • waive assignments per individual student
  • waive late penalties per individual student's assignment
  • validate gradescope student list by passing an email list of active students
    • e.g. one student has a low average grade, have they dropped the course?
  • exclude assignments which shouldn't be included in final grade
    • assignments automatically excluded if they don't have some minimum completion threshold
  • substitute one assignment in place of another (where substitute has higher percentage)
    • e.g. to "merge" two versions of the quiz with their own unique gradescope assignment
      1. substitute quiz_02 for quiz_01
      2. exclude quiz_02

Installation

pip3 install gradescope-mean

Usage

Download all gradescope assignments to some local scope.csv file (Assignments > Download Grades > Download CSV) and run:

python -m gradescope_mean scope.csv

to create output grade_full.csv using default configuartion. This first run will have created a config.yaml configuration file which you can modify to take advantage of the functionality listed above (details given in the configuration doc). To re-run with your configuration options:

python -m gradescope_mean scope.csv --config config.yaml

Other outputs

  • Provide an output file via --late_csv to observe late days per student-assignment pair.

  • Provide the --per_student flag to create a folder of student-specific csvs, helpful for emailing students the particulars of their grades.

  • Pass the --plot flag above to view histograms (hist.html) per assignment category:

histogram per category

Exporting Grades

The interface above yields a "grade_full.csv" which can be processed so its ready to import into canvas or Northeastern's Banner, see links for detail.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

gradescope_mean-0.0.12.tar.gz (15.4 kB view hashes)

Uploaded Source

Built Distribution

gradescope_mean-0.0.12-py3-none-any.whl (17.4 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page