ホームページ > バックエンド開発 > Python チュートリアル > Python パッケージング ツール distutils と setuptools の簡単な分析

Python パッケージング ツール distutils と setuptools の簡単な分析

不言
リリース: 2018-04-20 14:16:02
オリジナル
2603 人が閲覧しました

Python パッケージは開発において非常に一般的であり、一般的な使用手順は、すべての機能を備えた Python モジュール パッケージを作成し、モジュールをパッケージ化して公開し、インストールして使用することです。この記事では、Python パッケージング ツール distutils と setuptools の関連知識を紹介します。興味のある方は、ぜひ一緒にご覧ください: Python でパッケージをインストールする方法はたくさんあります:

    ソース パッケージ: python setup.py install
  1. オンラインインストール: pip install パッケージ名 (linux) / easy_install パッケージ名 (window)
  2. Python パッケージは開発において非常に一般的で、すべての機能を備えた Python モジュール パッケージを作成し、そのモジュールをパッケージ化します。をクリックしてから、公開、インストール、使用します。パッケージのパッケージ化とインストールは、最も一般的なタスクです。勉強中に、distutils と setuptools という 2 つのパッケージ化されたツールに出会い、勉強した後にメモを取りました。

distutilsdistutils は Python 標準ライブラリの一部です。このライブラリの目的は、開発者に便利なパッケージ化方法とユーザーに便利なインストール方法を提供することです。独自のモジュールを開発した後、distutils の setup.py パッケージを使用します。

1. Python

hello.py

def hello_fun():
 print "i say hello to you"
ログイン後にコピー


2. setup.pyファイルを作成します

setup.py

from distutils.core import setup
setup(
 name="hello_module",
 version="1.0",
 author="ljk",
 author_email="wilber@sh.com",
 py_modules=['hello'],
)
ログイン後にコピー



3. パッケージ化コマンドを実行します

<img src="https://img.php.cn/upload/article/000/153/291/c9ec895b33001f9a73ccf3328f67de4 1-1. png" alt= ""/>

カレントディレクトリにdistフォルダが自動生成されていることを再度確認してください。フォルダ内に対象ファイルである圧縮パッケージが存在します。記録ファイル MANIFEST もあります。

<img src="https://img.php.cn/upload/article/000/153/291/c9ec895b33001f9a73ccf3328f67de41-1.png" alt=""/>

再次查看当前目录下自动生成了一个文件夹dist,文件夹中有一个压缩包即为我们的目标文件。另外有一个记录文件MANIFEST。

四、安装模块

hello_module-1.0.tar.gz 是生成的python模块。切换到的我的python虚拟环境中,安装该模块。

使用python setup.py install

4. モジュールをインストールします

hello_module-1.0.tar.gz は、生成された Python モジュールです。 Python 仮想環境に切り替えて、モジュールをインストールします。

python setup.py install を使用してモジュールをインストールします。パスからもわかるように、モジュールは標準ライブラリの指定されたパスにインストールされます。

5. モジュールの使用

モジュールをインストールした後、Python 対話環境にモジュールをインポートします。モジュールは hello.py ファイルで、hello.py ファイル内の hello_fun() 関数を参照します。

setuptools

setuptoolsは、distutilsの拡張バージョンです。 setuptools には、Linux で特定のサービスを開始するのと同じように、非常に便利なentry_points 関数があります。たとえば、Firefox では Linux のコマンド ラインで Firefox ブラウザを起動できます。

インストールする前に、まずコマンドパスに影響がないことを確認してください。


1. 関数パッケージを作成します

フォルダーデモを作成し、フォルダー内に get_path.py と __init__.py の 2 つのファイルを作成します。 get_path.py は関数関数、__init__.py はパッケージの識別ファイルです。

get_path.py

import os
def fun():
 print "i am in the path:"
 print os.getcwd()
ログイン後にコピー


2. setup.py ファイルを設定します

setup.py ファイルを作成し、必要なパッケージ情報を入力します。 setup.py

#-*- encoding: UTF-8 -*-
from setuptools import setup
setup(
 name = "demo",    # 包名
 version = "0.1",    # 版本信息
 packages = [&#39;demo&#39;],   # 要打包的项目文件夹
 include_package_data=True, # 自动打包文件夹内所有数据
 zip_safe=True,    # 设定项目包为安全,不用每次都检测其安全性
 install_requires = [   # 安装依赖的其他包(测试数据)
 &#39;docutils>=0.3&#39;,
 &#39;requests&#39;,
 ],
 # 设置程序的入口为path
 # 安装后,命令行执行path相当于调用get_path.py中的fun方法
 entry_points={
  &#39;console_scripts&#39;:[
   &#39;path = demo.get_path:fun&#39;
          ]
 },
)
<br data-filtered="filtered"><br data-filtered="filtered">
ログイン後にコピー

このモジュールに必要なすべての依存関係を構成に書き込み、インストール中にダウンロードするアドレスを指定します。この方法を使用すると、インストール プロセスが簡素化されますが、十分ではありません。最良の方法は、pip の自動ダウンロードを使用することです。 🎜🎜🎜🎜3. パッケージ化🎜🎜🎜🎜🎜🎜🎜 🎜🎜 パッケージ化後、demo.egg-info と dist という 2 つのフォルダーが追加されます。 demo.egg-info はインストールに必要な情報で、dist 内の圧縮パッケージがインストール パッケージです。 🎜

查看dist/demo-0.1.tar.gz解压之后的文件。

四、安装包

五、使用包

安装之后在命令行中直接输入path,回车能够看到调用了get_path.py中的函数fun(),输出字符串。

同时也可以导入使用。

setuptools的进阶使用

上面使用setuptools时只是简单的用一个配置文件setup.py就完成了打包信息填写。在真实的开发环境中,往往是多个文件配合。以openstack的打包为例。openstack中引入了Pbr的管理工具。

pbr是setuptools的辅助工具,最初为openstack开发,基于d2to1。Pbr会读取和过滤setup.cfg中的内容,然后将解析后的数据提供给setup.py作为参数。

setup.cfg提供setup.py的默认参数,同时易于修改。Setup.py先解析setup.cfg文件,然后执行相关命令。包括以下功能:

1、从git中获取Version,AUTHORS和ChangeLog信息

2、SphinxAutodoc。pbr会扫描project,找到所有模块,生成stubfiles

3、Requirements。读取requirements.txt文件,生成setup函数需要依赖包

4、long_description。从README.rst、README.txt或者READMEfile中生成long_description参数

Pbr的文件很简单,如下。配置之后会自动寻找目录下的setup.cfg文件,解析文件参数给setup.py使用。

setup.py


from setuptools import setup
setuptools.setup(
setup_requires=[&#39;pbr&#39;],
pbr=True)
setup.cfg

[metadata]
name= keystone
version= 2015.2
summary= OpenStack Identity
description-file=
README.rst
author= OpenStack
author-email= openstack-dev@lists.openstack.org
home-page= http://www.openstack.org/
classifier=
Environment:: OpenStack
IntendedAudience :: Information Technology
IntendedAudience :: System Administrators
License:: OSI Approved :: Apache Software License
OperatingSystem :: POSIX :: Linux
ProgrammingLanguage :: Python
ProgrammingLanguage :: Python :: 2
ProgrammingLanguage :: Python :: 2.7
[files]
packages=
keystone
[global]
setup-hooks=
pbr.hooks.setup_hook
[egg_info]
tag_build=
tag_date= 0
tag_svn_revision= 0
[build_sphinx]
all_files= 1
build-dir= doc/build
source-dir= doc/source
[compile_catalog]
directory= keystone/locale
domain= keystone
ログイン後にコピー




以上がPython パッケージング ツール distutils と setuptools の簡単な分析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート