Skip to content

UCL-ARC/python-tooling

Β 
Β 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
UCL ARC Python tooling logo

UCL ARC Python Recommendations

This repository collects our recommendations for a research software project in Python. We have a website if you need some advice, and a template if you're starting from scratch.

πŸͺ Our template uses cookiecutter to set up a new package with our preferred tools ready to go.

Note

If you're making a package in a research community that already has a template, use theirs instead!

How to use our template

If you're comfortable with the command line, here are some quick start steps. We also have a more detailed tutorial that has been presented in workshops for researchers at UCL.

If you have uv installed, run:

uvx cookiecutter gh:ucl-arc/python-tooling --checkout latest

If you don't want to use uv you can install cookiecutter, then run without uvx:

cookiecutter gh:ucl-arc/python-tooling --checkout latest

cookiecutter will ask you questions to set up your project. Type your answer, or hit return without typing anything to use the defaults.

When finished, it prints some information to the terminal. These are tips for next steps like creating a repository and making a website for your package.

It will have created a directory for your project:

ls -ltr | tail -n1  # Show the last directory that was created

You can see the structure with the tree command. In our example we've called our project example-research-software-project:

tree example-research-software-project

To start working on your project:

  • change directory to your project directory,
  • initialise a git repository,
  • and install your new package editable mode.

You probably want to do this in a virtual environment. The comments show how to do this in uv with uv venv:

cd example-research-software-project
git init
# uv venv
# source .venv/bin/activate
uv sync

Need help?

You can ask questions in discussions or in the #helpme channel on UCL's Research Programming Hub Slack.

Contributors

Patrick J. Roddy
Patrick J. Roddy

πŸ€” πŸ› πŸ’» πŸ–‹ πŸ“– πŸ“‹ πŸ“† πŸ’¬ πŸ‘€ πŸ“’ ⚠️
Sam Cunliffe
Sam Cunliffe

πŸ€” πŸ› πŸ’» πŸ–‹ πŸ“– πŸ“‹ πŸ“† πŸ’¬ πŸ‘€ πŸ“’ ⚠️ βœ…
David Stansby
David Stansby

πŸ€” πŸ› πŸ’» πŸ–‹ πŸ“– πŸ“‹ πŸ“† πŸ‘€ ⚠️
Matt Graham
Matt Graham

πŸ› πŸ’» πŸ–‹ πŸ“– 🎨 πŸ“‹ πŸ‘€ πŸ“’ ⚠️ βœ…
sfmig
sfmig

πŸ› πŸ’» πŸ–‹ πŸ‘€ ⚠️
Paul Smith
Paul Smith

πŸ› πŸ’» πŸ–‹ πŸ“– πŸ’¬ πŸ‘€ ⚠️ βœ…
Renovate Bot
Renovate Bot

🚧
ruaridhg
ruaridhg

πŸ› πŸ’» πŸ–‹ πŸ‘€
Miguel Xochicale, PhD
Miguel Xochicale, PhD

πŸ› πŸ’» πŸ–‹ 🎨 πŸ“– πŸ‘€
yidilozdemir
yidilozdemir

πŸ“– ⚠️
Mosè Giordano
Mosè Giordano

πŸ› πŸ“– πŸ‘€
Tom Young
Tom Young

πŸ› πŸ–‹ πŸ‘€
Alessandro Felder
Alessandro Felder

πŸ› πŸ–‹
Adam Tyson
Adam Tyson

πŸ–‹
Will Graham
Will Graham

πŸ–‹ πŸ‘€
nikk-nikaznan
nikk-nikaznan

πŸ–‹
Katie Buntic
Katie Buntic

πŸ–‹
Robert Vickerstaff
Robert Vickerstaff

πŸ“–
David PΓ©rez-SuΓ‘rez
David PΓ©rez-SuΓ‘rez

πŸ’» πŸ’¬
llapira
llapira

πŸ›
pre-commit.ci
pre-commit.ci

🚧
Saransh Chopra
Saransh Chopra

πŸ“– πŸ–‹ 🚧 πŸ‘€ πŸ“’ βœ… πŸ“‹
Andrew Mitchell
Andrew Mitchell

πŸ›
Kimberly Meechan
Kimberly Meechan

πŸ› ️️️️♿️ πŸ‘€ βœ…
James Prime
James Prime

️️️️♿️ πŸ€”
Andrii Tsapko
Andrii Tsapko

️️️️♿️ πŸ’»
James Briant
James Briant

πŸ›