Skip to main content

Script for converting SWITRS reports to SQLite.

Project description

SWITRS-to-SQLite

Looking to get right to work with the data? Check out the cleaned dataset on Kaggle: California Traffic Collision Data from SWITRS

SWITRS-to-SQLite is a Python 3 script that converts the CSV files provided by the California Highway Patrol's Statewide Integrated Traffic Records System (SWITRS) into an SQLite database.

Instructions to download the SWITRS data can be found here.

Versioning

This repository follows SemVer. I will increment the MAJOR version if a change is backwards incompatible for either the Python command line or the structure of the output database.

Installation

The best way to install SWITRS-to-SQLite is with pip:

pip install switrs-to-sqlite

Or with UV:

uv tool install switrs-to-sqlite

This will give you access to the script simply by calling:

switrs_to_sqlite --help

Development Installation

For development, clone the repository and use UV to sync the environment (this handles the local package installation automatically):

git clone https://github.com/agude/SWITRS-to-SQLite.git
cd SWITRS-to-SQLite
uv sync --dev

SWITRS-to-SQLite requires Python 3.10+.

Usage

Using SWITRS-to-SQLite is simple; just point it to the unzipped files from SWITRS and it will run the conversion:

switrs_to_sqlite \
CollisionRecords.txt \
PartyRecords.txt \
VictimRecords.txt

The script also supports reading gziped records files:

switrs_to_sqlite \
CollisionRecords.txt.gz \
PartyRecords.txt.gz \
VictimRecords.txt.gz

The conversion process will take about an hour to write the database, which by default is saved to a file named switrs.sqlite3. The output file can be changed as follows:

switrs_to_sqlite \
CollisionRecords.txt \
PartyRecords.txt \
VictimRecords.txt \
-o new_db_file.sqlite3

The program provides the following help menu when called with --help:

usage: switrs_to_sqlite [-h] [--version] [-p {strict,ignore,replace}]
                        [-o OUTPUT_FILE]
                        collision_record party_record victim_record

Convert SWITRS text files to a SQLite3 database

positional arguments:
  collision_record      the CollisionRecords.txt file or the same file gzipped
  party_record          the PartyRecords.txt file or the same file gzipped
  victim_record         the VictimRecords.txt file or the same file gzipped

options:
  -h, --help            show this help message and exit
  --version             show program's version number and exit
  -p {strict,ignore,replace}, --parse-error {strict,ignore,replace}
                        how to handle unicode decoding errors in input files:
                        'strict' raises an error (default), 'ignore' skips
                        invalid characters, 'replace' substitutes a
                        replacement character
  -o OUTPUT_FILE, --output-file OUTPUT_FILE
                        file to save the database to

Unit Tests

SWITRS-to-SQLite uses pytest to run unit tests (contained in the tests folder). To run the tests:

uv run pytest -vv

Or with just:

just test

Run just with no arguments to see all available commands.

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

switrs_to_sqlite-4.4.0.tar.gz (76.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

switrs_to_sqlite-4.4.0-py3-none-any.whl (35.3 kB view details)

Uploaded Python 3

File details

Details for the file switrs_to_sqlite-4.4.0.tar.gz.

File metadata

  • Download URL: switrs_to_sqlite-4.4.0.tar.gz
  • Upload date:
  • Size: 76.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for switrs_to_sqlite-4.4.0.tar.gz
Algorithm Hash digest
SHA256 2d75b71f09d537748f4b3bb296421d50a9168f92aa7aae7ea9c5fc91c479298a
MD5 8e45b338980e5de47cc5f954c1b7509b
BLAKE2b-256 312fcaddce2fa30c25f900a0c5d4fc7e65ae6c5dcc851a836cbd048202276105

See more details on using hashes here.

Provenance

The following attestation bundles were made for switrs_to_sqlite-4.4.0.tar.gz:

Publisher: release.yml on agude/SWITRS-to-SQLite

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file switrs_to_sqlite-4.4.0-py3-none-any.whl.

File metadata

File hashes

Hashes for switrs_to_sqlite-4.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 29ae98f25665b301542c6a629ac2cbcf9cd1757a2b41fc1923d27b0d9402d6ee
MD5 bf58778f5c28e708c9e839751037c808
BLAKE2b-256 e4b2f1e5e7ff46d37cef2493c3fc8ca7a3a6449100efee4c756ae7a68721841f

See more details on using hashes here.

Provenance

The following attestation bundles were made for switrs_to_sqlite-4.4.0-py3-none-any.whl:

Publisher: release.yml on agude/SWITRS-to-SQLite

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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