Single-cell analysis template repository
This repository acts as a template notebook for the analysis of single-cell data and methods; the corresponding Jupyter Book is rendered here.
You can check out the CellRank 2 and CellRank protocol reproducibility repositories for example repositories following the same outline as this template, built off an earlier version of this template repo.
Project structure¶
data/Directory containing data relevant to project
Contains one subdirectory for each dataset
Proposed structure: each dataset has its own subdirectory containing
raw/: original, unaltered data that always exists unless the data has been loaded from an external data directoryprocessed/: processed data fromraw/results: analysis results
figures/Directory to collect generated figures
Contains one subdirectory for each dataset
jobs/Directory to collect scripts for submitting HPC jobs, e.g., with sbatch, (in
jobs/scripts/) and their generated output files (injobs/logs/)
notebooks/Directory containing Jupyter notebooks
Contains one subdirectory for each dataset
scripts/Directory containing Python or R scripts
Contains one subdirectory for each dataset
Setup¶
Rename
src/fancypackage/.Update
pyproject.tomlto include the correct informationProject name
Project description
Project-specific Python requirements
Project author
Project maintainers
Project URLs
Update
src/fancypackage/core/_constants.pyto include any paths relevant to your analysis and that should be accessible from any script or Jupyter notebookUpdate this README to include the relevant information about your project.
Ensure repository settings are set up correctly to build Jupyter Book:
In
Settings > Actions > General > Workflow permissions: Allow read and write permissions.In
Settings > Pages > Build and deployment: Set the branch togh-pages.
If you use uv with a custom environment name: update the
UV_PROJECT_ENVIRONMENTvalue in.envrc
Installation¶
uv¶
To install the accompanying packages with uv, you can run
uv venv
uv sync --group jupyter
uv run pre-commit install
# Optional: Add jupyter kernel
uv run ipython kernel install --user --env VIRTUAL_ENV .venv --name fancypackage --display-name "fancypackage"If you want to specify a custom environment name and specific Python version, you may use direnv and run
direnv allow
uv venv fancypackage-pyXY -p X.Y
uv sync --group jupyter
uv run pre-commit install
# Optional: Add jupyter kernel
uv run ipython kernel install --user --env VIRTUAL_ENV $UV_PROJECT_ENVIRONMENT --name fancypackage-pyXY --display-name "fancypackage-pyX.Y"pixi¶
To set up the project with pixi, run
pixi add --pypi --editable --no-install --frozen "fancypackage @ file://$(pwd)"
pixi install
pixi run setup-pre-commit
# Optional: Add jupyter kernel
pixi run ipython kernel install --user --env ~/.pixi/envs/default --name fancypackage --display-name "fancypackage"and to use a specific Python version and environment name, run
pixi add --frozen --feature pyXY python=X.Y
pixi workspace environment add fancypackage-pyXY --feature pyXY --feature dev --feature jupyter
pixi add --pypi --editable --no-install --frozen "fancypackage @ file://$(pwd)"
pixi install -e fancypackage-pyXY
pixi run setup-pre-commit
# Optional: Add jupyter kernel
pixi run ipython kernel install --user --env VIRTUAL_ENV .pixi/envs/fancypackage-pyXY --name fancypackage-pyXY --display-name "fancypackage-pyX.Y"Things to keep in mind¶
Whenever you use a new single-cell tool, add it to bio in pyproject.toml so isort can work correctly.
Workflow¶
The workflow for committing a notebook is as follows: Upon committing a notebook, the pre-commit hooks format your notebook and generate a corresponding script. You need to add the formatted notebook and Python script to the same commit for the commit to go through. The commit will now either be successful or not. If not, your Python script was formatted by the pre-commit hooks. In that case, you need to update your notebook accordingly, unstage the Python script, and recommit the notebook. You will iterate through this process until there are no inconsistencies between the notebook and its corresponding Python script.