Table des matières
PyScaffold Créer un projet
PyBuilder
Poésie
Maison développement back-end Tutoriel Python Quatre outils de gestion de projet et de construction Python, collection recommandée !

Quatre outils de gestion de projet et de construction Python, collection recommandée !

Apr 12, 2023 pm 10:52 PM
python 项目管理 构建工具

Quatre outils de gestion de projet et de construction Python, collection recommandée !

Python ne dispose pas d'un outil de gestion de projet et de construction standard de facto depuis si longtemps, ce qui entraîne une variété de structures de projet et de méthodes de construction Python. Cela peut refléter le libre arbitre de Python.

Contrairement à Java, qui est passé par une construction manuelle initiale, à Ant semi-automatisé, puis à Maven, il s'agit fondamentalement du standard de facto. Au cours de cette période, Maven a également accepté les défis d'autres Gradle (principalement promus par des projets Android), SBT (principalement des projets Scala), Ant+Ivy, Buildr, etc., mais il était difficile d'ébranler le statut de Maven dans le monde et des autres. a presque suivi la disposition du répertoire de Maven.

De retour en Python, il existait des outils de gestion de packages comme pip, pipenv et conda, mais il n'y avait aucun accord sur la disposition des répertoires du projet.

De nombreux aspects de la construction suivent toujours la méthode traditionnelle Makefile, puis ajoutez setup.py et build.py pour utiliser le code du programme pour installer et construire. Concernant la disposition du répertoire de projet, certains créent des modèles de projet, puis créent des outils pour appliquer les modèles de projet.

Ce qui suit est un bref aperçu de l'utilisation de quatre outils

  1. CookieCutter
  2. PyScaffold
  3. PyBuilder
  4. Poetry

CookieCutter Une structure de répertoires de projet Python classique

$ pip install cookiecutter
$ cookiecutter gh:audreyr/cookiecutter-pypackage
# 以 github 上的 audreyr/cookiecutter-pypackage 为模板,再回答一堆的问题生成一个 Python 项目
......
project_name [Python Boilerplate]: sample
......
Copier après la connexion

Dernière génération par cookiecutter Le modèle de projet ressemble à ceci :

$ tree sample
sample
├── AUTHORS.rst
├── CONTRIBUTING.rst
├── HISTORY.rst
├── LICENSE
├── MANIFEST.in
├── Makefile
├── README.rst
├── docs
│ ├── Makefile
│ ├── authors.rst
│ ├── conf.py
│ ├── contributing.rst
│ ├── history.rst
│ ├── index.rst
│ ├── installation.rst
│ ├── make.bat
│ ├── readme.rst
│ └── usage.rst
├── requirements_dev.txt
├── sample
│ ├── __init__.py
│ ├── cli.py
│ └── sample.py
├── setup.cfg
├── setup.py
├── tests
│ ├── __init__.py
│ └── test_sample.py
└── tox.ini
3 directories, 26 files
Copier après la connexion

Il s'agit probablement du cadre principal de la structure de répertoires actuellement populaire. Les principaux éléments sont :

$ tree sample
sample
├── Makefile
├── README.rst
├── docs
│ └── index.rst
├── requirements.txt
├── sample
│ ├── __init__.py
│ └── sample.py
├── setup.cfg
├── setup.py
└── tests
 ├── __init__.py
 └── test_sample.py
Copier après la connexion

Le répertoire d'exemple de projet est répété. Les fichiers sources Python sont placés dans le répertoire d'exemple. et les fichiers de test sont placés dans le répertoire tests. Ajoutez un répertoire docs pour stocker la documentation, README.rst et d'autres fichiers d'installation, setup.cfg et Makefile pour la construction.

Il s'agit en fait d'une structure de projet Python très classique. La prochaine build utilise la commande make Entrez make et vous verrez les instructions définies dans le fichier Makefile.

$ make
cleanremove all build, test, coverage and Python artifacts
clean-buildremove build artifacts
clean-pycremove Python file artifacts
clean-test remove test and coverage artifacts
lint check style
test run tests quickly with the default Python
test-all run tests on every Python version with tox
coverage check code coverage quickly with the default Python
docs generate Sphinx HTML documentation, including API docs
servedocscompile the docs watching for changes
releasepackage and upload a release
dist builds source and wheel package
installinstall the package to the active Python's site-packages
Copier après la connexion

Pour utiliser le processus de construction ci-dessus, vous devez installer les packages correspondants, tels que tox, wheel, cover, sphinx, flake8, ils peuvent tous être installés via pip. Ensuite, vous pouvez faire des tests, créer une couverture, créer des documents, créer une distribution, etc. Parmi eux, make docs peut générer un beau document web.

PyScaffold Créer un projet

PyScaffold Comme son nom l'indique, il s'agit d'un outil utilisé pour créer un échafaudage pour les projets Python. Installer et utiliser :

$ pip install pyscaffold
$ putup sample
Copier après la connexion

Un projet Python est créé de cette manière. le modèle sélectionné par cookiecutter plus tôt. C'est juste qu'il place les fichiers sources dans le répertoire src au lieu du répertoire exemple.

$ tree sample
sample
├── AUTHORS.rst
├── CHANGELOG.rst
├── CONTRIBUTING.rst
├── LICENSE.txt
├── README.rst
├── docs
│ ├── Makefile
│ ├── _static
│ ├── authors.rst
│ ├── changelog.rst
│ ├── conf.py
│ ├── contributing.rst
│ ├── index.rst
│ ├── license.rst
│ ├── readme.rst
│ └── requirements.txt
├── pyproject.toml
├── setup.cfg
├── setup.py
├── src
│ └── sample
│ ├── __init__.py
│ └── skeleton.py
├── tests
│ ├── conftest.py
│ └── test_skeleton.py
└── tox.ini
Copier après la connexion

Tox est l'outil utilisé pour construire l'ensemble du projet. tox est un outil de test et de construction automatisé qui crée un environnement virtuel Python pendant le processus de construction, permettant un environnement propre pour les tests et la construction.

tox -av peut afficher toutes les tâches définies dans tox.ini :

$ tox -av
default environments:
default -> Invoke pytest to run automated tests
additional environments:
build -> Build the package in isolation according to PEP517, see https://github.com/pypa/build
clean -> Remove old distribution files and temporary build artifacts (./build and ./dist)
docs-> Invoke sphinx-build to build the docs
doctests-> Invoke sphinx-build to run doctests
linkcheck -> Check for broken links in the documentation
publish -> Publish the package you have been developing to a package index server. By default, it uses testpypi. If you really want to publish your package to be publicly accessible in PyPI, use the `-- --repository pypi` option.
Copier après la connexion

Utilisez tox -e build, tox -e docs, etc. quelle commande exécuter

Au cours de mon expérience avec la commande tox, à chaque fois Chaque étape semble lente. La création d'une machine virtuelle devrait prendre un certain temps.

PyBuilder

Il est préférable de regarder un autre outil de build PyBuilder. La structure de répertoires qu'il crée est très proche de Maven Jetons un coup d'œil

$ pip install pybuilder
$ mkdir sample && cd sample# 项目目录需手工创建
$ pyb --start-project# 回答一些问题后创建所需的目录和文件
Copier après la connexion

Après avoir terminé, jetez un œil à sa structure de répertoires :

$ tree sample
.
├── build.py
├── docs
├── pyproject.toml
├── setup.py
└── src
 ├── main
 │ ├── python
 │ └── scripts
 └── unittest
 └── python
Copier après la connexion

Build. process Toujours en utilisant la commande pyb, vous pouvez utiliser pyb -h pour afficher l'aide, et pyb -t pour lister toutes les tâches PyBuilder ajoutées sous forme de plug-ins, et la configuration du plug-in est dans la build. fichier py.

$ pyb -t sample
Tasks found for project "sample":
 analyze -Execute analysis plugins.
 depends on tasks: prepare run_unit_tests
 clean - Cleans the generated output.
 compile_sources - Compiles source files that need compilation.
 depends on tasks: prepare
coverage - <no description available>
 depends on tasks: verify
 install - Installs the published project.
 depends on tasks: package publish(optional)
 package - Packages the application. Package a python application.
 depends on tasks: compile_sources run_unit_tests(optional)
 prepare - Prepares the project for building. Creates target VEnvs
 print_module_path - Print the module path.
print_scripts_path - Print the script path.
 publish - Publishes the project.
 depends on tasks: package verify(optional) coverage(optional)
 run_integration_tests - Runs integration tests on the packaged application.
 depends on tasks: package
run_unit_tests - Runs all unit tests. Runs unit tests based on Python's unittest module
 depends on tasks: compile_sources
upload - Upload a project to PyPi.
verify - Verifies the project and possibly integration tests.
 depends on tasks: run_integration_tests(optional)
$ pyb run_unit_tests sample
Copier après la connexion

PyBuilder crée également un environnement virtuel avant de construire ou de tester. À partir de la version 0.12.9, vous pouvez ignorer l'étape de création d'un environnement virtuel via le paramètre --no-venvs. Si --no-venvs est utilisé, le code Python sera exécuté dans l'environnement Python actuel exécutant pyb et les dépendances requises devront être installées manuellement.

Les dépendances du projet doivent également être définies dans le fichier build.py.

@init
def set_properties(project):
 project.depends_on('boto3', '>=1.18.52')
 project.build_depends_on('mock')
Copier après la connexion

Les dépendances ci-dessus seront installées lorsque pyb sera exécuté pour créer un environnement virtuel, et les tests et les builds y seront exécutés.

Poésie

La dernière poésie, je pense qu'il s'agit d'une version Python plus mature avec une activité de projet plus élevée. Elle a des fonctions de gestion de confiance plus puissantes. Utilisez la poésie add boto3 pour ajouter des dépendances, la poésie show - -tree montre l'arbre des dépendances. . Jetez un œil à comment installer et créer un projet

$ pip install poetry
$ poetry new sample
Copier après la connexion

Le projet qu'il crée est plus simple que celui ci-dessus

$ tree sample
sample
├── README.rst
├── pyproject.toml
├── sample
│ └── __init__.py
└── tests
 ├── __init__.py
 └── test_sample.py
Copier après la connexion

Si vous donnez de la poésie nouvelle avec le paramètre --src, l'échantillon du répertoire du fichier source sera placé dans le répertoire src , c'est-à-dire sample/src/ sample.

poetry init générera le fichier pyproject.toml dans le répertoire actuel et la génération des répertoires doit être effectuée manuellement.

Il ne se concentre pas sur la génération de documents, la vérification des spécifications du code ou la couverture du code. Sa configuration de projet est plus centralisée, le tout dans le fichier pyproject.toml. Qu'est-ce que toml ? Il s'agit d'un format de fichier de configuration Tom's Obvious, Minimal Language (https://github.com/toml-lang/toml).

pyproject.toml est quelque peu similaire au fichier package.json de NodeJS, tel que l'ajout de poésie, l'installation de poésie Ligne de commandement

# 往 pyproject.toml 中添加对boto3 的依赖并安装(add 还能从本地或 git 来安装依赖 ),
poetry add boto3
# 将依照 pyproject.toml 文件中定义安装相应的依赖到当前的 Python 虚拟环境中
# 比如在 <test-venv>/lib/python3.9/site-packages 目录中,安装好模块后也可让测试用例使用
poetry install
Copier après la connexion

其他主要的

1.poetry build# 构建可安装的 *.whl 和 tar.gz 文件
2.poetry shell# 会根据定义在 pyproject.toml 文件中的依赖创建并使用虚拟环境
3.poetry run pytest# 运行使用 pytest 的测试用例,如 tests/test_sample.py
4.poetry run python -m unittest tests/sample_tests.py# 运行 unittest 测试用例
5.poetry export --without-hashes --output requirements.txt# 导出 requirements.txt 文件, --dev导出含 dev 的依赖,或者用 poetry export --without-hashes > requirements.txt
Copier après la connexion

poetry run 能执行任何系统命令,只是它会在它要的虚拟环境中执行。所以可以想见,poetry 的项目要生成文档或覆盖率都必须用 poetry run ... 命令来支持 sphinx, coverage 或 flake8。

在 sample 目录(与 pyproject.toml 文件平级)中创建文件 my_module.py, 内容为

def main():
 print('hello poetry')
Copier après la connexion

然后在 pyproject.toml 中写上。

[tool.poetry.scripts]
my-script="sample.my_module:main"
Copier après la connexion

再执行

$ poetry run my-script
Copier après la connexion

就会输出 "hello poetry"。

通过对以上四个工具的认识,项目结构的复杂度由 cookiecutter-pyproject -> PyScaffold -> PyBuilder -> Poetry 依次降低,使用的难度大略也是相同的顺序

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Python: jeux, GUIS, et plus Python: jeux, GUIS, et plus Apr 13, 2025 am 12:14 AM

Python excelle dans les jeux et le développement de l'interface graphique. 1) Le développement de jeux utilise Pygame, fournissant des fonctions de dessin, audio et d'autres fonctions, qui conviennent à la création de jeux 2D. 2) Le développement de l'interface graphique peut choisir Tkinter ou Pyqt. Tkinter est simple et facile à utiliser, PYQT a des fonctions riches et convient au développement professionnel.

PHP et Python: comparaison de deux langages de programmation populaires PHP et Python: comparaison de deux langages de programmation populaires Apr 14, 2025 am 12:13 AM

PHP et Python ont chacun leurs propres avantages et choisissent en fonction des exigences du projet. 1.Php convient au développement Web, en particulier pour le développement rapide et la maintenance des sites Web. 2. Python convient à la science des données, à l'apprentissage automatique et à l'intelligence artificielle, avec syntaxe concise et adaptée aux débutants.

Comment Debian Readdir s'intègre à d'autres outils Comment Debian Readdir s'intègre à d'autres outils Apr 13, 2025 am 09:42 AM

La fonction ReadDir dans le système Debian est un appel système utilisé pour lire le contenu des répertoires et est souvent utilisé dans la programmation C. Cet article expliquera comment intégrer ReadDir avec d'autres outils pour améliorer sa fonctionnalité. Méthode 1: combinant d'abord le programme de langue C et le pipeline, écrivez un programme C pour appeler la fonction readdir et sortir le résultat: # include # include # include # includeIntmain (intargc, char * argv []) {dir * dir; structDirent * entrée; if (argc! = 2) {

Python et temps: tirer le meilleur parti de votre temps d'étude Python et temps: tirer le meilleur parti de votre temps d'étude Apr 14, 2025 am 12:02 AM

Pour maximiser l'efficacité de l'apprentissage de Python dans un temps limité, vous pouvez utiliser les modules DateTime, Time et Schedule de Python. 1. Le module DateTime est utilisé pour enregistrer et planifier le temps d'apprentissage. 2. Le module de temps aide à définir l'étude et le temps de repos. 3. Le module de planification organise automatiquement des tâches d'apprentissage hebdomadaires.

Certificat NGINX SSL Mise à jour du tutoriel Debian Certificat NGINX SSL Mise à jour du tutoriel Debian Apr 13, 2025 am 07:21 AM

Cet article vous guidera sur la façon de mettre à jour votre certificat NGINXSSL sur votre système Debian. Étape 1: Installez d'abord CERTBOT, assurez-vous que votre système a des packages CERTBOT et Python3-CERTBOT-NGINX installés. Si ce n'est pas installé, veuillez exécuter la commande suivante: Sudoapt-getUpDaSuDoapt-GetInstallCertBotpyThon3-Certerbot-Nginx Étape 2: Obtenez et configurez le certificat Utilisez la commande Certbot pour obtenir le certificat LETSCRYPT et configure

Comment configurer le serveur HTTPS dans Debian OpenSSL Comment configurer le serveur HTTPS dans Debian OpenSSL Apr 13, 2025 am 11:03 AM

La configuration d'un serveur HTTPS sur un système Debian implique plusieurs étapes, notamment l'installation du logiciel nécessaire, la génération d'un certificat SSL et la configuration d'un serveur Web (tel qu'Apache ou Nginx) pour utiliser un certificat SSL. Voici un guide de base, en supposant que vous utilisez un serveur Apacheweb. 1. Installez d'abord le logiciel nécessaire, assurez-vous que votre système est à jour et installez Apache et OpenSSL: SudoaptupDaSuDoaptupgradeSudoaptinsta

Guide de développement du plug-in de Gitlab sur Debian Guide de développement du plug-in de Gitlab sur Debian Apr 13, 2025 am 08:24 AM

Développer un plugin Gitlab sur Debian nécessite des étapes et des connaissances spécifiques. Voici un guide de base pour vous aider à démarrer avec ce processus. Installation de GitLab Tout d'abord, vous devez installer GitLab sur votre système Debian. Vous pouvez vous référer au manuel d'installation officiel de Gitlab. Obtenez un jeton d'accès API avant d'effectuer l'intégration de l'API, vous devez d'abord obtenir le jeton d'accès API de GitLab. Ouvrez le tableau de bord GitLab, recherchez l'option "AccessTokens" dans les paramètres utilisateur et générez un nouveau jeton d'accès. Sera généré

Quel service est Apache Quel service est Apache Apr 13, 2025 pm 12:06 PM

Apache est le héros derrière Internet. Ce n'est pas seulement un serveur Web, mais aussi une plate-forme puissante qui prend en charge un trafic énorme et fournit un contenu dynamique. Il offre une flexibilité extrêmement élevée grâce à une conception modulaire, permettant l'expansion de diverses fonctions au besoin. Cependant, la modularité présente également des défis de configuration et de performance qui nécessitent une gestion minutieuse. Apache convient aux scénarios de serveur qui nécessitent des besoins complexes hautement personnalisables.

See all articles