Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/camille-004/python_project
https://github.com/camille-004/python_project
Last synced: 23 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/camille-004/python_project
- Owner: camille-004
- License: gpl-3.0
- Created: 2024-06-10T04:36:20.000Z (7 months ago)
- Default Branch: main
- Last Pushed: 2024-08-21T08:54:45.000Z (5 months ago)
- Last Synced: 2024-08-21T10:13:34.964Z (5 months ago)
- Language: Python
- Size: 27.3 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Python Project Template 2024
![CI](https://github.com/camille-004/python_project/workflows/CI/badge.svg)
Welcome to the **Python Project Template 2024**. This will help get you started with the most modern Python tools and best practices.
## 🚀 Features
- **Depdendency Management** with [Poetry](https://python-poetry.org/)
- **Code Linting and Formatting** with [Ruff](https://github.com/astral-sh/ruff)
- **Type Checking** with [MyPy](https://mypy-lang.org/)
- **Automating Testing** with [Pytest](https://docs.pytest.org/en/8.2.x/)
- **Pre-commit Hooks** with [pre-commit](https://pre-commit.com/)
- **CI** with [GitHub Actions](https://github.com/features/actions)## 📚 Table of Contents
- [Getting Started](#getting-started)
- [Project Structure](#project-structure)
- [Makefile Commands](#makefile-commands)
- [Pre-commit Hooks](#pre-commit-hooks)
- [Continuous Integration](#continuous-integration)
- [Contributing](#contributing)
- [License](#license)## 🏁 Getting Started
### Prerequisites
Make sure you have the following installed:
- [Python 3.12+](https://www.python.org/downloads/)
- [Poetry](https://python-poetry.org/docs/#installing-with-pipx)### Installation
1. **Clone the repository**
```sh
git clone https://github.com/camille-004/python_project.git
cd python_project
```2. **Install dependencies**
```sh
make install
```3. **Set up pre-commit hooks**
```sh
poetry run pre-commit install
```### Adapting the Project
1. **Rename the project**
Update the `pyproject.toml` file with your project's details:
```toml
[tool.poetry]
name = "your_project_name"
version = "0.1.0"
description = "Your project description"
authors = ["Your Name "]
readme = "README.md"
packages = [{include = "your_project_name"}]
```Then, rename the source code directory from `python_project` to the value of `your_project_name`.
2. **Customize or replace the `README`**
3. **Start developing**
Add your source code to the `your_project_name/` directory and your tests to the `tests/` directory.
## 📂 Project Structure
```
.
├── .github
│ └── workflows
│ └── ci.yml
├── .gitignore
├── .pre-commit-config.yaml
├── LICENSE
├── Makefile
├── README.md
├── pyproject.toml
├── python_project
│ └── __init__.py
└── tests
├── __init__.py
└── test_sample.py
```## 🛠️ Makefile Commands
This project uses a `Makefile` to simplify various tasks:
- **Installing depedencies**
```sh
make install
```- **Running linters**
```sh
make lint
```- **Formatting code**
```sh
make format
```- **Type-checking the code**
```sh
make type-check
```- **Running tests**
```sh
make test
```## 📝 Pre-commit Hooks
Pre-commit hooks are configured to run the following checks before every commit:
- **Lint**: `make lint`
- **Format**: `make format`
- **Type Check**: `make type-check`## ⚙️ Continuous Integration
This project uses GitHub Actions for Continuous Integration. Check `.github/workflows/ci.yml` for the steps in how the workflow is defined:
- **Install dependencies**
- **Run linters**
- **Type-check the code**
- **Run tests**## 🤝 Contributing
Contributions are welcome! Please open an issue or submit a pull request if you have any improvements or new features.
1. **Fork the repository**
2. **Create a new branch**
3. **Make your changes**
4. **Submit a pull request**## 📄 License
This project is licensed under the GNU General Public License. See the [LICENSE](LICENSE) file for details.
---
Happy coding. 🚀