Skip to main content

Split schedule into smaller class sizes

Project description

Split Schedule

Tests Status pre-commit.ci status Coverage PyPI version PyPI - Python Version

This package takes a class list and reduces the number of students in each class by a specified amount. This is done by splitting the classes across days. Each individual student's day is kept the same for each of his/her classes.

The class list should be supplied as an Excel(xlsx) file with all students on a single sheet, a csv file, or a Pandas DataFrame containing the columns:

  • block = The class period as a number (i.e. 1, 2, 3, etc.)
  • class = The name of the class
  • student = The name of the student

The generated schedule will contain the fillowing columns:

  • block = The class period as a number (i.e. 1, 2, 3, etc.)
  • class = The name of the class
  • total_students = The total number of students for a block across all days
  • max_students = The maximum number of students allowed in a block each day
  • num_classes = The total number of days needed in order to allow for the maximum class size
  • day_number = The day for the class. This can be used as desired. For example 1 = Monday, 2 = Tuesday, etc.
  • student = The name of the student

Installation

Note: Python 3.8 or greater is required

Using a virtual environmnet is recommended for installing this package. Once the virtual environment is created and activated install the package with:

pip install split-schedule

Usage

ScheduleBuilder Methods

  • build_schedule_from_df: Builds the schedule from a Pandas DataFrame
    • df: The DataFrame that contains the schedule to split
    • reduce_by (optinal): The amount by which the class size should be reduced. Default = 0.2
    • smallest_allowed (optinal): The smallest a class should be. This can be used to override the reduce_by amount in cases where the class would be smaller than the desired amount. For example if classes are being reduced 50% (0.5) if the smallest allowd class is 10 and a class has 10 students at the start, then all 10 of these students would be kept in one class rather than reducing the size below 10. Default = 1
    • max_tries (optinal): The maximum number of times the program will restart itself tying to find a viable schedule. If the maximum number of tries is exceded with no viable schedule found a SchedulingError error will occur meaning no possible way was found to split the schedule with parameters supplied. Default = 10
    • verbose (optinal): Setting verbose to True will result in log output being written to the terminal as the schedule is being build. Default = False
  • build_schedule_from_file: Builds the schedule from either an Excel(xlsx) file or a csv file.
    • schedule_file_path: The path to the schedule file, including the name of the file. The file path can be either a string or a Path object. Excel files in xlsx format or csv files are accepted.
    • reduce_by (optinal): The amount by which the class size should be reduced. Default = 0.2
    • smallest_allowed (optinal): The smallest a class should be. This can be used to override the reduce_by amount in cases where the class would be smaller than the desired amount. For example if classes are being reduced 50% (0.5) if the smallest allowd class is 10 and a class has 10 students at the start, then all 10 of these students would be kept in one class rather than reducing the size below 10. Default = 1
    • max_tries (optinal): The maximum number of times the program will restart itself tying to find a viable schedule. If the maximum number of tries is exceded with no viable schedule found a SchedulingError error will occur meaning no possible way was found to split the schedule with parameters supplied. Default = 10
    • verbose (optinal): Setting verbose to True will result in log output being written to the terminal as the schedule is being build. Default = False
  • save_schedule: Saves the generated schedule to a file.
    • save_path: The path to which the generated schedule file should be saved, including the desired name of the file. The file path can be either a string or a Path object. Excel files in xlsx format or csv files are accepted.

ScheduleBuilder Properties

  • final_schedule_df: This is a Pandas DataFrame that contains the generated schedule. Before the schedule is created the property will be None

Examples

Note: Examples uses Mac/Linux type file paths. For Windows use paths like c:\path\to\original_file.xlsx and c:\path\to\generated_schedule.xlsx.

Create a schedule from an Excel file, then save the generated schedule to another Excel file.

from split_schedule import ScheduleBuilder

schedule_builder = ScheduleBuilder()
schedule_builder.build_schedule_from_file("/path/to/file.xlsx")
schedule_builder.save_schedule("/path/to/generated_schedule.xlsx")

Create a schedule from an Excel file, then print the resulting schedule DataFrame.

from split_schedule import ScheduleBuilder

schedule_builder = ScheduleBuilder()
schedule_builder.build_schedule_from_file("/path/to/file.xlsx")
print(schedule_builder.final_schedule_df)

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

split-schedule-0.3.5.tar.gz (9.8 kB view details)

Uploaded Source

Built Distribution

split_schedule-0.3.5-py3-none-any.whl (8.5 kB view details)

Uploaded Python 3

File details

Details for the file split-schedule-0.3.5.tar.gz.

File metadata

  • Download URL: split-schedule-0.3.5.tar.gz
  • Upload date:
  • Size: 9.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.14 CPython/3.9.13 Linux/5.15.0-1014-azure

File hashes

Hashes for split-schedule-0.3.5.tar.gz
Algorithm Hash digest
SHA256 9579028e2c292206c72f64aaad5d976f0bf489dc75d67489d6b34de5ac92b08f
MD5 f37a53786e489ead7d76e2c6675b636a
BLAKE2b-256 047cfd49b31dcc8b389128f86bd94f364f97ba6aa7033938a7b3710e0e3bace3

See more details on using hashes here.

File details

Details for the file split_schedule-0.3.5-py3-none-any.whl.

File metadata

  • Download URL: split_schedule-0.3.5-py3-none-any.whl
  • Upload date:
  • Size: 8.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.14 CPython/3.9.13 Linux/5.15.0-1014-azure

File hashes

Hashes for split_schedule-0.3.5-py3-none-any.whl
Algorithm Hash digest
SHA256 8c08389729eeb87111d7cf39d2006dd853310469a841b5b1a3d794294c96738b
MD5 56648594cca064495c934e6c73f33617
BLAKE2b-256 fcc668453136360782cf7ca97c35cbe38acf35f65668c331f72bc1ddf45384f3

See more details on using hashes here.

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