ホームページ >バックエンド開発 >Python チュートリアル >Python パッケージング ツール distutils と setuptools の簡単な分析
Python パッケージは開発において非常に一般的であり、一般的な使用手順は、すべての機能を備えた Python モジュール パッケージを作成し、モジュールをパッケージ化して公開し、インストールして使用することです。この記事では、Python パッケージング ツール distutils と setuptools の関連知識を紹介します。興味のある方は、ぜひ一緒にご覧ください: Python でパッケージをインストールする方法はたくさんあります:
distutilsdistutils は Python 標準ライブラリの一部です。このライブラリの目的は、開発者に便利なパッケージ化方法とユーザーに便利なインストール方法を提供することです。独自のモジュールを開発した後、distutils の setup.py パッケージを使用します。
hello.py
def hello_fun(): print "i say hello to you"
from distutils.core import setup setup( name="hello_module", version="1.0", author="ljk", author_email="wilber@sh.com", py_modules=['hello'], )
<img src="https://img.php.cn/upload/article/000/153/291/c9ec895b33001f9a73ccf3328f67de4%201-1.%20png" alt="">
<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
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 = ['demo'], # 要打包的项目文件夹
include_package_data=True, # 自动打包文件夹内所有数据
zip_safe=True, # 设定项目包为安全,不用每次都检测其安全性
install_requires = [ # 安装依赖的其他包(测试数据)
'docutils>=0.3',
'requests',
],
# 设置程序的入口为path
# 安装后,命令行执行path相当于调用get_path.py中的fun方法
entry_points={
'console_scripts':[
'path = demo.get_path:fun'
]
},
)
<br data-filtered="filtered"><br data-filtered="filtered">
查看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=['pbr'], 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 サイトの他の関連記事を参照してください。