Python是一种高级编程语言,已经成为了web开发、数据科学、机器学习等领域的主要语言之一。当你开发了一个Python代码库,你希望在其他地方使用它,那么如何分发这个代码库呢?这就需要用到Python Setup.py,一个构建和分发Python软件的核心工具。本文将详细介绍Python Setup.py的使用方法。
一、什么是Python Setup.py
Python Setup.py是Python提供的一个核心工具,用于打包、构建、安装和分发Python软件。通过Python Setup.py,我们可以创建一个可安装的Python软件包,将它上传到Python Package Index (PyPI), 并供其他Python用户使用。
通常,一个Python软件包应该包含以下内容:
* setup.py文件,它包含了包的元数据。
* 包的源代码和其他相关文件,例如README文件。
* 测试代码,以确保包的正确性。
* 发布脚本,以便构建和分发软件。
二、构建Python软件包
在构建Python软件包之前,我们需要安装setuptools和wheel模块。这可以通过pip慕容来进行安装,如下所示:
pip install setuptools wheel
接下来,我们需要创建一个项目目录,并放置源代码和其他相关文件。目录结构如下:
myproject/ README.md LICENSE myproject/ __init__.py mymodule.py tests/ test_mymodule.py
其中,myproject/目录是我们的项目根目录,README.md和LICENSE是项目说明文档和许可证。myproject/myproject/目录包含了我们的Python库源代码,tests/目录包含我们的单元测试。
接下来,我们需要创建一个setup.py文件,来描述我们的模块的信息。这个文件应该放在myproject/目录下,内容如下:
from setuptools import setup, find_packages setup( name='myproject', version='0.1', description='My awesome project', long_description=open('README.md').read(), author='Your Name', author_email='you@example.com', url='https://github.com/you/myproject', packages=find_packages(exclude=('tests',)), install_requires=[ 'numpy', 'pandas', 'matplotlib', ], classifiers=[ 'Development Status :: 3 - Alpha', 'Intended Audience :: Developers', 'License :: OSI Approved :: MIT License', 'Programming Language :: Python :: 3', 'Programming Language :: Python :: 3.4', 'Programming Language :: Python :: 3.5', ], )
在这个文件中,我们指定了我们的项目名称、版本号、项目描述、作者信息、依赖项、项目主页以及其他与项目相关的信息。注意,我们还指定了我们的包应该包含哪些文件。我们将使用find_packages()函数来查找我们的包。
接下来,我们需要将我们的代码提交到PyPI。我们可以使用以下命令:
python setup.py sdist bdist_wheel twine upload dist/*
这个命令将在dist/目录下生成源代码包和wheel包,并将其上传到PyPI。
三、安装和使用Python软件包
完成上述步骤后,其他用户就可以使用pip install命令来安装和使用我们的Python软件包了:
pip install myproject
然后,我们就可以在Python中使用这个软件包了:
import myproject myproject.myfunction()
四、Python Setup.py的高级用法
除了上面介绍的基本用法外,Python Setup.py还有许多高级用法,允许我们更精细地控制我们的包,包括版本控制、依赖项管理、构建选项等。以下是一些示例:
(1) 版本控制
我们可以使用setuptools_scm模块来处理软件包的版本控制。这个模块将根据Git提交历史自动计算我们包的版本号:
from setuptools import setup, find_packages setup( name='myproject', use_scm_version=True, setup_requires=['setuptools_scm'], ... )
(2) 依赖项管理
我们可以使用install_requires参数来列出我们包的依赖项:
from setuptools import setup, find_packages setup( name='myproject', install_requires=[ 'numpy', 'pandas', 'matplotlib', ], ... )
我们还可以使用extras_require参数来定义可选的依赖项:
from setuptools import setup, find_packages setup( name='myproject', install_requires=[ 'numpy', 'pandas', 'matplotlib', ], extras_require={ 'dev': ['flake8', 'black'], 'test': ['pytest', 'pytest-cov'], }, ... )
(3) 构建选项
我们可以使用cmdclass参数来定义自定义构建命令。例如,我们可以定义一个clean命令来清理生成的文件:
from setuptools import setup, find_packages from setuptools.command.clean import clean as CleanCommand class Clean(CleanCommand): def run(self): import os, shutil shutil.rmtree('dist', ignore_errors=True) shutil.rmtree('build', ignore_errors=True) shutil.rmtree('myproject.egg-info', ignore_errors=True) for root, dirs, files in os.walk('.'): for file in files: if file.endswith('.pyc') or file.endswith('.pyo') or file.endswith('~') or file.startswith('.'): os.unlink(os.path.join(root, file)) for dir in dirs: if dir == '__pycache__': shutil.rmtree(os.path.join(root, dir)) setup( name='myproject', cmdclass={ 'clean': Clean, }, ... )
我们也可以使用entry_points参数来定义可执行文件:
from setuptools import setup, find_packages setup( name='myproject', entry_points={ 'console_scripts': [ 'mycommand=myproject.cli:main', ], }, ... )
总结
Python Setup.py是构建和分发Python软件的核心工具,通过它,我们可以创建可安装的Python软件包,将它上传到PyPI,供其他Python用户使用。本文介绍了Python Setup.py的使用方法和高级用法,希望能对Python开发者有所帮助。