文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

手把手教你发布 Python 项目开源包

2024-12-03 04:11

关注

作者以 SciTime 项目(一个对算法训练时间进行估计的包)的发布为例,详细解释了发布的每个步骤。

注意:本文假设你在 GitHub 上已经有一个想要打包和发布的项目。

第 0 步:获取项目许可证

在做其他事之前,由于你的项目要开源,因此应该有一个许可证。获取哪种许可证取决于项目包的使用方式。开源项目中一些常见许可证有 MIT 或 BSD。

要在项目中添加许可证,只需参照以下链接中的步骤,将 LICENSE 文件添加到项目库中的根目录即可:https://help.github.com/en/articles/adding-a-license-to-a-repository

第 1 步:让你的代码准备就绪

要将项目进行打包,你需要做一些预备工作:

让你的项目结构正确就位。通常情况下,项目库的根目录包含一个以项目名称命名的文件夹,项目的核心代码应该位于此文件夹中。在这个文件夹之外是运行和构建包(测试、文档等)所需的其他代码。

核心文件夹应包括一个(或多个)模块和一个 __init__.py 文件,该文件包含你希望让终端用户访问的类/函数。此文件还可以包含包的版本,以便于终端用户访问。

理想情况下,应使用 logging 包来设置合理的日志记录系统(而不是用 prints 输出)。

理想情况下,应将你的核心代码分配到一个或多个类中。

  1. from .estimate import Estimator 

以__init__.py 为例,如果 Estimator 是终端用户将会访问的类(该类在 estimate.py 文件中定义) 

  1. import logging  
  2. class LogMixin(object):  
  3.     @property  
  4.     def logger(self):  
  5.         name = '.'.join([self.__module__, self.__class__.__name__])  
  6.         FORMAT = '%(name)s:%(levelname)s:%(message)s'  
  7.         logging.basicConfig(format=FORMATlevel=logging.DEBUG)  
  8.         logger = logging.getLogger(name)  
  9.         return logger 

以日志系统为例:LogMixin 类可以在其他任何类中使用

第 2 步:使用打包工具创建 setup.py

在你的项目有了一套结构之后,你应该在项目库的根目录下添加 setup.py 文件。这有助于所有发布和版本维护过程的自动化。以下是 setup.py 的例子 

  1. from setuptools import setup  
  2. from os import path  
  3. DIR = path.dirname(path.abspath(__file__))  
  4. INSTALL_PACKAGES = open(path.join(DIR, 'requirements.txt')).read().splitlines()  
  5. with open(path.join(DIR, 'README.md')) as f:  
  6.     README = f.read()  
  7. setup(  
  8.     name='scitime' 
  9.     packages=['scitime'],  
  10.     description="Training time estimator for scikit-learn algorithms" 
  11.     long_description=README 
  12.     long_description_content_type='text/markdown' 
  13.     install_requires=INSTALL_PACKAGES 
  14.     version='0.0.2' 
  15.     url='http://github.com/nathan-toubiana/scitime' 
  16.     author='Gabriel Lerner & Nathan Toubiana' 
  17.     author_email='toubiana.nathan@gmail.com' 
  18.     keywords=['machine-learning', 'scikit-learn', 'training-time'],  
  19.     tests_require=[  
  20.         'pytest',  
  21.         'pytest-cov',  
  22.         'pytest-sugar'  
  23.     ],  
  24.     package_data={  
  25.         # include json and pkl files  
  26.         '': ['*.json', 'modelsscitime_data.py  
  27.     */setup.py 

.coveragerc 文件示例

第 4 步:标准化语法和代码风格

你还需要确保你的代码遵循 PEP8 准则(即具有标准样式并且语法正确)。同样,有很多工具可以帮助你解决。这里我们用了 flake8。

第 5 步:创建一个合理的文档

现在你的项目已经测试过了,结构也很好了,是时候添加一个合理的文档。首先是要有一个好的 readme 文件,它会在你的 Github 项目库的根目录上显示。完成后,加上以下几点会更好:

Pull 请求和 issue 模板:当创建新的 Pull 请求或 issue 时,这些文件可以根据你的需求给你的描述提供模板。

贡献指南(contribution guide)。应该在贡献指南中简单地说明你希望外部用户如何协助你改进这个包。

由于 readme 文件应该相当综合,因此通常会有一个更详细的文档。你可以用 sphinx 来完成,然后在 readthedocs 上管理文档。与文档相关的文件通常放在 docs/文件夹中。

包含标签和说明的项目库示例

第 6 步:创建持续集成

此时,你的项目离发布就绪不远了。但是,在每次提交之后,必须更新文档、运行测试以及检查样式和覆盖率似乎有点难以应付。幸运的是,持续集成(CI)可以帮助你完成。你可以在每次提交之后使用 GitHub 的 webhook 来自动执行所有的这些操作。以下是我们在 SciTime 中使用的一套 CI 工具:

对于运行测试,我们使用了 travis ci 和 appveyor(用于 Windows 平台上的测试)。对于 Travis CI,除了在项目库上设置 webhook 之外,你还必须创建一个.travis.yml 文件,在该文件中,你不仅可以运行测试,还可以上传更新的覆盖率输出以及检查样式和格式。通过创建 appveyor.yml 文件,appveyor 也可以这样做。

codecov 和 readthdocs 也有专用的 webhook 

  1. language: python  
  2. python:  
  3.   - "3.6"  
  4. # command to install dependencies  
  5. install:  
  6.   - pip install -r requirements.txt  
  7.   - pip install flake8  
  8.   - pip install pytest-cov  
  9.   - pip install codecov  
  10. # command to run tests  
  11. script:  
  12.   - python -m pytest --cov=scitime  
  13.   - ./build_tools/flake_diff.sh  
  14. after_success:  
  15.   - codecov 

.travis.yml 文件的示例:请注意,每次提交,测试都需要与检查测试覆盖率一起进行。但还有一个 flake8 检查 

  1. environment:  
  2.   matrix:  
  3.     - PYTHON: "C:\\Python36-x64"  
  4. install:  
  5.   # We need wheel installed to build wheels  
  6.   - "%PYTHON%\\python.exe -m pip install -r requirements.txt"  
  7.   - "%PYTHON%\\python.exe -m pip install pytest==3.2.1"  
  8. build: off  
  9. test_script:  
  10.   - "%PYTHON%\\python.exe -m pytest" 

appveyor.yml 文件示例:这里我们只运行测试

这将使更新项目库的整个过程更加容易。

集成 webhook 的提交历史记录示例

第 7 步:创建你的第一个 release 和 publication

此时,你即将发布的包应与以下类似: 

  1. your_package/  
  2.    __init__.py  
  3.    your_module.py  
  4. docs/  
  5. tests/  
  6. setup.py  
  7. travis.yml  
  8. appveyor.yml  
  9. .coveragerc  
  10. .codecov.yml  
  11. README.md  
  12. LICENSE  
  13. .github/  
  14.    CODE_OF_CONDUCT.md  
  15.    CONTRIBUTING.md  
  16.    PULL_REQUEST_TEMPLATE.md  
  17.    ISSUE_TEMPLATE/ 

现在可以发布了!首先要做的是在 GitHub 上创建你的第一个 release——这是为了在给定的时间点跟踪项目的状态,每次版本更改时都需要创建新的 release。

完成后,唯一要做的就是发布包。发布 python 包最常见的平台是 PyPI 和 Conda。以下我们将描述如何用两者发布:

完成!

现在,你的包应该已经发出去,并且任何人都可以使用了!虽然大部分工作都完成了,但是你仍然需要维护你的项目,你需要进行一些更新:这大体上意味着每次进行重大更改时都要更改版本,创建新的 release,并再次执行第 7 步。 

 

来源:马哥Linux运维内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯