Parse Troopmaster export files into TOML, YAML, or JSON
Project description
tm_parser
(c) Michael Perkins, 2023, 2024
Installation
pip install tm-parser
Instructions:
In troopmaster, under reports -> advancement -> individual history
- select all the scouts you want to report
- select all the ranks you want to report
- Do not select "Omit details on completed ranks"
- Other than that, any other options can be included or excluded (I only tested a few configurations. if it doesn't work, select everything)
generate the report and save it to a PDF. -- we will use "export.pdf" as the output file name
by default, the output is to the console in YAML format
Then run:
tmparse -o output.yaml export.pdf
Options:
-t --output-type [yaml], json or toml
-o --outfile output filename
This produces output of the desired type.
YAML can be read in python with:
import yaml
with open('output.yaml') as f:
scouts = yaml.safe_load(f)
Using TmParser in code:
from tm_parser import Parser
#initializing the parser automatically parses the file and stores
#the information in TmParser().scouts
parser = TmParser(infile='filename.pdf')
# Iterating on the parser yields scouts
for scout in parser:
print('----------------------------------------------')
print(f"{scout['Data']['Name']:26}Date Eagle Req")
print('----------------------------------------------')
## do something with scout
if "Merit Badges" in scout:
#sort merit badges by date ascending
for badge, data in sorted(scout['Merit Badges'].items(),
key=lambda x: x[1]['date']):
print(f"{badge:26}{data['date']} {data['eagle_required']}")
Yields:
----------------------------------------------
Smith, John Date Eagle Req
----------------------------------------------
Climbing 2017-03-11 False
Mammal Study 2017-06-29 False
Leatherwork 2017-06-30 False
Swimming 2017-06-30 True
Kayaking 2018-06-29 False
Wilderness Survival 2018-06-29 False
Rifle Shooting 2018-06-29 False
First Aid 2018-09-29 True
By default the information is a dictionary, with the scout names as keys, and each scout is a dictionary with the following keys:
- Activity Totals
- Data - contains biographical data
- Leadership
- Merit Badges
- Order of the Arrow
- Partial Merit Badges
- Rank Advancement
- Training Courses
All dates have been parsed into datetime.date objects, in YYYY-MM-DD format, and are null if not assigned in the incoming data.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file tm_parser-0.10.5.tar.gz
.
File metadata
- Download URL: tm_parser-0.10.5.tar.gz
- Upload date:
- Size: 22.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: python-httpx/0.26.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2dc65041403ed6baf7e00992305740da8ffd8c2bef6cbbcdc9974fcb14a6b683 |
|
MD5 | 6faafcc946e78a02b2fb598f6e4508be |
|
BLAKE2b-256 | 4f82b34b4a3fae32322ea7608f788ed909759a56d7672c43ed394d88ec07d736 |
File details
Details for the file tm_parser-0.10.5-py3-none-any.whl
.
File metadata
- Download URL: tm_parser-0.10.5-py3-none-any.whl
- Upload date:
- Size: 27.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: python-httpx/0.26.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 15f5343e7ac69dbb11e7e342de8b8014c6cec451a8590c0f3014078ccc5052e4 |
|
MD5 | 6f49090d0215ff1792f1e68c9b4972e1 |
|
BLAKE2b-256 | 49bd6329c7314105fdefc3da08bb986af8da60a45507c3f0e0de30ba5571b2e2 |