Skip to main content

Cookiecutter template for a Python package

Project description

CI Python Versions Package Version License Discord

logo_scicookie.png

SciCookie is a project template designed to simplify scientific Python project creation. It provides an initial structure with recommended tools, workflows, and industry best practices, saving developers time and effort. Built upon the PyOpenSci recommendations, it offers a foundation that adheres to scientific Python standards while remaining customizable to specific project needs.

Key Features

  • Project Structure: Choose between "src" (code in a subdirectory) and "flat" (all files in the top-level directory) layouts.
  • Packaging & Dependencies: Supports Poetry, Flit, meson-python, setuptools, PDM, Hatch, Maturin, scikit-build-core, Pixi, uv, or setuptools + pybind11 for flexible build systems.
  • Testing & Linting: Integrates with pytest and hypothesis (testing), black, ruff and prettier (auto-formatting), bandit (security), pydocstyle (documentation style), vulture (unused code detection), flake8 (code style), ruff (linter), ShellCheck (static analysis of shell scripts), Coverage (code coverage testing), and McCabe (cyclomatic complexity analysis) for a robust development environment.
  • Version Control & Automation: Includes initial git integration, conda (base environment) support, pre-commit hooks, continuous integration with GitHub Actions, CircleCI, Azure Pipelines and GitLab CI, automation with Make and Makim, and release workflows with semantic-release.
  • Documentation: Offers options for mkdocs, sphinx-rst, sphinx-myst, jupyter-book or quarto documentation generation.
  • Containerization: Provides the ability to add initial files for running and managing containers using Docker(Podman is supported via docker-compose).

Benefits

  • Reduces boilerplate code: SciCookie eliminates the need to write repetitive project setup code, allowing developers to focus on core functionality.
  • Ensures consistency: Enforces a standardized structure, promoting code maintainability and collaboration.
  • Adheres to best practices: Leverages PyOpenSci recommendations for efficient scientific Python development.
  • Improves code quality: Integrates with various testing and linting tools for better code hygiene.
  • Automates workflows: Streamlines processes like documentation generation, version control, and continuous integration.

Getting Started

Prerequisites

  • Python: Make sure you have Python installed on your system. You can check by running python --version or python3 --version in your terminal. If you don't have it, download it from here.

Installation

  • Install Cookiecutter (if not already installed): Open your terminal and run the following command: pip install scicookie

Project Creation

  1. Navigate to your desired project directory: Use the cd command to navigate to the directory where you want to create your new Python package project. For example: cd ~/dev/my-python-projects (Replace ~/dev/my-python-projects with your preferred directory path.)

  2. Generate the project using SciCookie: Once you're in your desired directory, run the following command to generate a new Python package project using SciCookie: scicookie

(SciCookie will create a new directory structure for your project, including files and folders commonly used in scientific Python projects. You can now start editing and customizing your project to fit your specific needs.)

Use a profile as an alternative

A profile is a set of template-specific settings. OSL has a specific profile with the libraries we recommend. You can use it to generate the project by running:

scicookie --profile osl

Note: If the --profile osl flag omitted, the default SciCookie profile will be used Another community can also create a specific profile with the configurations they recommend.

You can also use it with pipx:

pipx run scicookie --profile osl

Community

Support

  • Star us on GitHub.
  • Stay tuned for upcoming support options.

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

scicookie-0.14.0.tar.gz (102.0 kB view details)

Uploaded Source

Built Distribution

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

scicookie-0.14.0-py3-none-any.whl (144.8 kB view details)

Uploaded Python 3

File details

Details for the file scicookie-0.14.0.tar.gz.

File metadata

  • Download URL: scicookie-0.14.0.tar.gz
  • Upload date:
  • Size: 102.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.13.9 Linux/6.11.0-1018-azure

File hashes

Hashes for scicookie-0.14.0.tar.gz
Algorithm Hash digest
SHA256 9f27beb253fb501e8723fd8c74f76829b6135b576558d95207c3ff6579dac68d
MD5 fada4906b66eb13fa492037acc19f0c7
BLAKE2b-256 77fe4006d8c778c09ab9729cf021357903d6e83d42e5605c05eb04056b5477ed

See more details on using hashes here.

File details

Details for the file scicookie-0.14.0-py3-none-any.whl.

File metadata

  • Download URL: scicookie-0.14.0-py3-none-any.whl
  • Upload date:
  • Size: 144.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.13.9 Linux/6.11.0-1018-azure

File hashes

Hashes for scicookie-0.14.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9fcd8402e69f534265436e2abd0c4e78f4f3c9387763297b31bfa62ce5e67bae
MD5 3e0dedf217f941f306a44c02bb8b22b2
BLAKE2b-256 0c4d35f5860730e72a99c57fb04f1c827f218f8bf06162d2c26c318821a8005e

See more details on using hashes here.

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