Miscellaneous utilities for nbdev projects.
Project description
cjm-nbdev-utils
Install
pip install cjm_nbdev_utils
Project Structure
nbs/
└── env_gen.ipynb # Generate an environment.yml from an nbdev-style settings.ini
Total: 1 notebook
Module Dependencies
graph LR
env_gen[env_gen<br/>env_gen]
No cross-module dependencies detected.
CLI Reference
gen_env_from_settings Command
usage: gen_env_from_settings [-h] [--settings SETTINGS] [--name NAME]
[--extras EXTRAS] [--no-editable]
[--include-pip-reqs] [--no-include-pip-reqs]
[--out OUT] [--stdout]
Generate environment.yml from nbdev settings.ini
options:
-h, --help show this help message and exit
--settings SETTINGS Path to settings.ini
--name NAME Environment name override
--extras EXTRAS Editable pip extras to install, e.g. 'dev' or
'dev,docs'. Use '' to install no extras.
--no-editable Do not include editable install (-e .).
--include-pip-reqs Also include 'requirements' and 'dev_requirements'
from settings.ini in pip section.
--no-include-pip-reqs
Do not include pip requirements from settings.ini
(default).
--out OUT Output file path.
--stdout Write YAML to stdout instead of a file.
For detailed help on any command, use
gen_env_from_settings <command> --help.
Module Overview
Detailed documentation for each module in the project:
env_gen (env_gen.ipynb)
Generate an environment.yml from an nbdev-style settings.ini
Import
from cjm_nbdev_utils.env_gen import (
DEFAULT_ENV_NAME,
DEFAULT_CHANNELS,
read_settings,
get_section,
split_list,
normalize_python_spec,
collect_values,
emit_yaml,
main
)
Functions
def read_settings(
path: str # Path to settings.ini file
) -> configparser.ConfigParser: # Configured ConfigParser object
"Read settings.ini file with percent-style interpolation."
def get_section(
cp: configparser.ConfigParser # ConfigParser object
)
"Get configuration section from ConfigParser. nbdev puts keys at top-level (DEFAULT). Falls back to first section if present."
def split_list(
val: str | None # String value to split (can be None)
) -> List[str]: # List of unique, non-empty strings preserving order
"Split space- and/or comma-separated lists while respecting quotes."
def normalize_python_spec(
min_py: str=None # Minimum Python version string
) -> str: # Normalized Python specification string or None
"Normalize Python version specification for conda. Accepts ">=3.10", "3.10", "3.9.*", etc. If bare like "3.10", makes it ">=3.10"."
def collect_values(
cfg # Configuration section dictionary - TODO: Add type hint
) -> Tuple[str, List[str], List[str], List[str], List[str]]: # Tuple of (env_name, channels, conda_reqs, pip_reqs, dev_pip_reqs)
"Collect configuration values from settings."
def emit_yaml(
name: str, # Environment name
channels: List[str], # List of conda channels
conda_deps: List[str], # List of conda dependencies
pip_lines: List[str], # List of pip packages
) -> str: # YAML formatted string
"Generate environment.yml content. Manual YAML emitter to avoid extra dependencies."
def main()
"""
Generate environment.yml from nbdev settings.ini.
Reads: lib_name, min_python, conda_channels, conda_requirements,
requirements, dev_requirements (all optional).
Writes: environment.yml (or stdout).
Adds an editable pip install (-e ".[EXTRAS]") by default.
Examples:
python gen_env_from_settings.py
python gen_env_from_settings.py --name myproj-dev --extras dev,docs --out env.yml
python gen_env_from_settings.py --no-editable --stdout
python gen_env_from_settings.py --no-include-pip-reqs
"""
Variables
DEFAULT_ENV_NAME = 'nbdev-env'
DEFAULT_CHANNELS = [1 items]
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
cjm_nbdev_utils-0.0.3.tar.gz
(9.4 kB
view details)
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 cjm_nbdev_utils-0.0.3.tar.gz.
File metadata
- Download URL: cjm_nbdev_utils-0.0.3.tar.gz
- Upload date:
- Size: 9.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5c4d78a9feaf5b21e439f9fa72931ab50e2fbe79b2e123b901577ae03325a8e3
|
|
| MD5 |
1c31e8f5b0cb5857f9e327f4b1491773
|
|
| BLAKE2b-256 |
50761ba9c941d5872d8428fcde8ff01e7d1a284d1355a6c92e8a4238de815478
|
File details
Details for the file cjm_nbdev_utils-0.0.3-py3-none-any.whl.
File metadata
- Download URL: cjm_nbdev_utils-0.0.3-py3-none-any.whl
- Upload date:
- Size: 10.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
22730ab3a7f0bc67bb37badb7557c9ec16cb966c2b1e8414cc681c7d0ecdd3d1
|
|
| MD5 |
9ac91507ab9884126c1cd907cda3e1b3
|
|
| BLAKE2b-256 |
5bacea8e369e32fa90fadbe99b5f2a448465d2e3de69ab781c0c4d8cdfdbf438
|