Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/ebezzam/python-dev-tips

Minimal package to demonstrate good Python development habits
https://github.com/ebezzam/python-dev-tips

formatting github-actions packaging profiling python unit-testing

Last synced: 3 months ago
JSON representation

Minimal package to demonstrate good Python development habits

Awesome Lists containing this project

README

        

***************************************
pydevtips: Python Development Tips
***************************************

.. image:: https://readthedocs.org/projects/pydevtips/badge/?version=latest
:target: http://pydevtips.readthedocs.io/en/latest/
:alt: Documentation Status

.. image:: https://github.com/ebezzam/python-dev-tips/actions/workflows/poetry.yml/badge.svg
:target: https://github.com/ebezzam/python-dev-tips/blob/main/.github/workflows/poetry.yml
:alt: Unit tests and formatting

.. image:: https://img.shields.io/badge/YouTube-%23FF0000.svg?style=for-the-badge&logo=YouTube&logoColor=white
:target: https://youtu.be/BmTBQicddqc?si=cnVcbo36EFNh6dg7
:alt: Recording

.. image:: https://img.shields.io/badge/Google_Slides-yellow
:target: https://docs.google.com/presentation/d/1D1_JywMl2rjaeuVzpykPBOJsDIuwQKGOJB4EFZjej2s/edit#slide=id.g2eaa4b61f15_0_1346
:alt: Slides

.. .. |ss| raw:: html

..

.. .. |se| raw:: html
..

|

Reproducibility is important for software: *if it's not reproducible, it's not useful*.
Even if you don't plan on sharing your code, imagine
coming back to a project after a few weeks, or having
to install it on a new machine. You'll be all the more thankful to your
past self if you have a clear way to install and run your code.

This repository is a collection of tips and tricks for developing stable
and reproducible Python code. There is a slight focus on scientific
computing, but the general principles can apply to most Python projects.
If you're reading this from `GitHub `_, please check out the
`documentation `_ for a
more in-depth explanation of the topics covered.

The intended audience is myself (as I often find myself going to past
projects to find how I did something!), but also for students and
anyone who is interested in learning some new tricks or even
sharing their own! I try to follow the principles laid out here on
development and reproducibility, so feel free to point out any lapses
or suggest improvements, either by opening an issue or pull request.

As is typical in open source, there are many ways to do the same thing.
But hopefully this gives you a starting point. Feel free to pick and
choose the features that you like. This flexibility is one of the best
(and worst parts) of open source. Some of the things we cover:

* Packaging and distribution with `Poetry `_.
* Virtual environments with `Conda `_ and `virtualenv `_.
* Version control with Git/GitHub.
* Reproducible examples with `Hydra `_.
* Documentation with `Sphinx `_.
* Code formatting with Black, Flake8, and isort.
* Unit tests and continuous integration with `pytest `_ and `GitHub Actions `_.
* Remote development with `VS Code ` and `SSH `_.

The accompanying
`slides `__
and `video `__
are from a tutorial given at LauzHack's `Deep Learning Bootcamp `__.
Feel free to modify and use it for your own purposes.

.. note::

A good amount of this documentation and code is written with `GitHub
Copilot `_, which I highly recommend for development. If you don't like
writing documentation, it is a great way to get started as it is able to
understand the functionality of your code and produce meaningful text to describe it.
It should be used be used with caution, *but it can be a great tool for getting started*
and you often you need to make a few tweaks (*like the previous repetition*).
But it's a huge time-saver!

Installation
============

This "dummy" package can be installed with pip:

.. code:: bash

pip install pydevtips

Or from source. Firstly, Poetry must be installed: https://python-poetry.org/docs/#installation

.. code:: bash

# -- recommend using pipx
pipx install poetry

# -- or with official installer
# curl -sSL https://install.python-poetry.org | python3 -

# I recommend creating virtual environment in the project folder
poetry config virtualenvs.in-project true

Then the following commands can be run:

.. code:: bash

# get source code
git clone [email protected]:ebezzam/python-dev-tips.git
cd python-dev-tips

# create new environment, press enter to accept
# -- important to set python version, otherwise `python` executable may not exist
# -- (would be `python3` instead)
conda create -n project_env python=3.11

# view available environments
conda info --envs

# activate environment
conda activate project_env

# install package locally
(project_env) poetry install --with dev

# install pre-commit hooks
(project_env) pre-commit install

# run tests
(project_env) pytest

# deactivate environment
(project_env) conda deactivate

Or without ``conda`` and just Poetry:

.. code:: bash

# get source code
git clone [email protected]:ebezzam/python-dev-tips.git
cd python-dev-tips

# install package locally
poetry install --with dev
# -- `poetry env info` to see where the virtual environment is located

# install pre-commit hooks
poetry run pre-commit install

# run tests
poetry run pytest

## NOTE that Python related commands need to be run
## with `poetry run` or by activating the virtual environment
## https://python-poetry.org/docs/basic-usage/#activating-the-virtual-environment

Examples
========

Examples can be found in the ``examples`` and ``notebooks`` folders.
Scripts from the ``examples`` folder should be run from the root of the
repository, e.g.:

.. code:: bash

python examples/real_convolve.py

Parameter setting is done with `hydra `_. More on that
in the `Reproducible examples `_
section of the documentation.

TODO
====

- switch to ruff for code formatting: https://docs.astral.sh/ruff/
- numba: https://numba.pydata.org/
- picking a license
- change documentation links to main branch
- github page
- point out features in scripts: object-oriented, asserts, tqdm, type hints
- manifest file to not include file in package
- GitHub actions for releasing to PyPi when changes to version
- pytorch compatible
- Cython / C++