Generated from aind-library-template
Project description
aind-data-schema-models
Installation
aind-data-schema-models is a dependency of aind-data-schema. You should not need to install it directly.
Contributing
Install the dev dependencies:
pip install -e .[dev]
How to add a new model class
tl;dr
Add new classes to the _generators/models/*.csv files or create new files containing Enum-derived classes directly in the src folder.
Run ./run_all.sh in the top-level folder to rebuild models from their CSV files.
Details
The model class files, brain_atlas.py etc, are auto-generated. You should never need to modify the class files directly.
Instead, take a look at the jinja2 templates in the folder _generators/templates. The filename of the template is used to pull the corresponding .csv file and populate the data DataFrame. In the template you can pull data from the various columns and use them to populate each of the fields in your class.
To re-build all the models, run the run_all.sh bash script in the root folder, which loops through the template files and runs them through the generate_code function.
There are a few special cases, e.g. if data are missing in columns they will show up as float: nan. See the organizations.txt template for examples of how to handle this.
Documentation
Internal registries need to be enumerated in the aind-data-schema file src/aind_data_schema/utils/docs/registries_generator.py in the variable registries. This list controls what classes will have documentation automatically generated and cross-referenced correctly.
If you add a new external registry, you need to write the documentation manually in the aind-data-schema file docs/source/aind_data_schema_models/external.md.
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file aind_data_schema_models-5.3.0.tar.gz.
File metadata
- Download URL: aind_data_schema_models-5.3.0.tar.gz
- Upload date:
- Size: 340.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
348dc170df68b1aa8f36f1df063c58cfae5899315130274c74b365f9400587a0
|
|
| MD5 |
3fe387d40db7620b8b11e6ad321ebc83
|
|
| BLAKE2b-256 |
1a37e18ec9fa2fb2276c7774bca8dd0940a342002f79ca5a90aca207e979aa6b
|
File details
Details for the file aind_data_schema_models-5.3.0-py3-none-any.whl.
File metadata
- Download URL: aind_data_schema_models-5.3.0-py3-none-any.whl
- Upload date:
- Size: 309.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
705575b124222d0f137fe988f3c1b66fd8cc77087517a325d4c2e9eb6772e56e
|
|
| MD5 |
695a796c8566c3f3dcef80a3472dcab3
|
|
| BLAKE2b-256 |
1965b7ec5a4744add259390ea09d9eaa2828af1ae73b3b7f2547684b72b95462
|