使用SetupTools 管理你的项目打包工作

在这里插入图片描述

Setuptools 是一个用于 Python 的包管理工具,主要用于构建、打包和分发 Python 软件包。它是 distutils 的增强版,提供了更多的功能和灵活性,是 Python 包管理的核心模块之一。

功能与特点

  1. 依赖管理:Setuptools 提供了强大的依赖管理功能,可以自动解析和安装软件包所需的依赖项。
  2. 自动生成入口点:它能够自动发现并生成命令行脚本的入口点,例如将 Python 脚本转换为可执行文件。
  3. 模块发现:通过 find_packages() 函数,Setuptools 可以自动发现并包含所有包含 __init__.py 文件的目录。
  4. 打包与分发:Setuptools 支持创建多种格式的包,包括 wheel、sdist 和 egg 等,并可以通过 pip 等工具进行分发。
  5. 扩展支持:它允许开发者通过扩展(如 setuptools.command)来添加自定义构建步骤或命令。
  6. 元数据管理:通过 setup.py 文件,开发者可以定义软件包的元数据,如名称、版本、作者信息等。

安装方法

Setuptools 可以通过 pip 安装:

pip install setuptools

安装完成后,可以通过以下命令验证是否安装成功:

pip list | grep setuptools

通常情况下,安装 Python 和 pip 后,setuptools 会默认自带。

使用场景

  1. 打包与发布:开发者可以使用 setuptools 将自己的代码打包成一个可安装的 Python 包,并上传到 PyPI(Python Package Index)供他人下载和使用。
  2. 依赖管理:在项目中,可以通过 setup.py 文件指定项目所需的依赖包,并在运行时自动安装这些依赖。
  3. 自动化构建:通过编写 setup.py 脚本,可以实现自动化构建、安装和发布的过程。

常用命令

  • python setup.py build:构建项目。
  • python setup.py install:安装项目。
  • python setup.py sdist:生成源码包。
  • python setup.py bdist_wheel:生成 wheel 包。

示例代码

以下是一个简单的 setup.py 文件示例:

from setuptools import setup, find_packagessetup(name="example",version="0.1",packages=find_packages(),install_requires=["numpy","scipy"],entry_points={"console_scripts": ["example = example.__main__:main"]}
)

在这个示例中,find_packages() 自动发现并包含所有模块,install_requires 指定了依赖项,entry_points 定义了命令行脚本。

Setuptools 是 Python 开发中不可或缺的工具之一,它简化了包的构建、分发和管理过程。无论是个人开发者还是企业用户,都可以通过它高效地管理和发布 Python 软件包。

要使用Setuptools创建包含多个子包的复杂Python项目,可以按照以下步骤进行:

  1. 创建项目结构
    首先,创建一个项目目录,并在其中创建子包。每个子包应该包含一个__init__.py文件,即使该文件为空。例如:
   my_project/├── setup.py ├── my_project/│   ├── __init__.py│   ├── subpackage1/│   │   ├── __init__.py│   │   └── module1.py │   └── subpackage2/│       ├── __init__.py│       └── module2.py 
  1. 编写setup.py文件
    setup.py是Setuptools的核心配置文件,用于定义项目的元数据和打包选项。对于包含多个子包的项目,可以使用find_packages()函数自动发现所有子包。以下是一个示例setup.py文件:
   from setuptools import setup, find_packagessetup(name='my_project',version='0.1',packages=find_packages(),install_requires=['requests','numpy',# 其他依赖项],author='你的名字',author_email='你的邮箱',description='项目的简短描述',long_description=open('README.md ').read(),long_description_content_type='text/markdown',url='项目的URL',classifiers=['Development Status :: 3 - Alpha','Intended Audience :: Developers','License :: OSI Approved :: MIT License','Programming Language :: Python :: 3','Programming Language :: Python :: 3.6','Programming Language :: Python :: 3.7','Programming Language :: Python :: 3.8','Programming Language :: Python :: 3.9',],python_requires='>=3.6',)

在这个示例中,find_packages()函数会自动查找并包含所有子包。install_requires参数用于指定项目的依赖项。

  1. 创建README.md文件
    README.md文件用于提供项目的详细描述,可以使用Markdown格式编写。这个文件的内容会被读取并显示在PyPI页面上。

  2. 构建和发布项目
    使用build工具来构建项目。首先,确保已经安装了build工具:

   pip install build

然后,运行以下命令来构建项目:

   python -m build

构建完成后,会在项目目录下生成一个dist文件夹,其中包含.tar.gz.whl文件,即Python包。

  1. 发布到PyPI
    使用twine工具将构建好的包发布到PyPI。首先,确保已经安装了twine工具:
   pip install twine

然后,运行以下命令来发布包:

   twine upload dist/*

运行上述命令后,会提示你输入PyPI的用户名和密码。发布成功后,其他人就可以通过pip install my_project来安装你的项目了。

通过以上步骤,你可以使用Setuptools创建并发布一个包含多个子包的复杂Python项目。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/34087.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

人工智能与人的智能,改变一生的思维模型【8】逆向思维

逆向偏差思维模型:顶尖高手如何「反常识」破局 (斯坦福决策科学中心认证的逆向思考框架) 一、直击本质:什么是逆向偏差思维? 定义: 逆向偏差思维是一种主动对抗本能认知倾向的决策模式,通过系…

YOLO优化之扫描融合模块(SimVSS Block)

研究背景 在自动驾驶技术快速发展的背景下,目标检测作为其核心组成部分面临着严峻挑战。 驾驶场景中目标尺度和大小的巨大差异 ,以及 视觉特征不显著且易受噪声干扰 的问题,对辅助驾驶系统的安全性构成了潜在威胁。 传统的卷积神经网络(CNN)虽然在目标检测领域取得了显著…

(全)2024下半年真题 系统架构设计师 综合知识 答案解析01

系统架构设计师第二版教程VIP课程https://edu.csdn.net/course/detail/40283 操作系统 下列选项中不能作为预防死锁措施的是 。 A. 破坏“循环等待"条件 B. 破坏“不可抢占”条件 C. 破坏“互斥”条件 D. 破坏“请求和保持”条件 答案:C 解析&…

通义万相 2.1 + 蓝耘算力,AI 视频生成的梦幻组合

在这个科技日新月异的时代,人工智能不断刷新着我们对世界的认知。一次偶然的机会,我借助北京蓝耘科技股份有限公司提供的算力支持,踏上了使用通义万相 2.1 进行 AI 视频生成的奇妙之旅。 目录 1.1初遇蓝耘科技: 1.2通义万相 2.1…

链表·简单归并

cur->next la; //将 p指针所指向的链表节点的 next 指针(也就是 p 节点的下一个节点的指针)指向 l1 所指向的链表节点。简单来说,就是把 la 节点连接到 p 节点的后面,更新了链表的连接关系。 p la; //将p指针的值更新为 la …

kmp报错→Cannot find skiko-windows-x64.dll.sha256

1、前言 学习kmp(Kotlin MultiPlatform简称)过程中报了错误,这个报错在直接运行desktop的main方法才会出现,用gradle运行却不会报错,新建的kmp项目也不会出现,我学习的写了一些代码的项目才会出现。   运…

MySQL(事物下)

目录 一 多版本并发控制( MVCC )是一种用来解决 读-写冲突 的无锁并发控制 1. 前置知识 示例: 二 Read View 1. 当事物进行快照读(读历史数据)会MySQL会创建一个Read Vidw类对象,用来记录和当前一起并发的事物(活跃的事物)&a…

星型组网模块的两种交互方式优缺点解析

星型组网模块简介 星型组网模块工作在433MHz频段;星型组网模块集主机(协调器)、终端为一体,星型组网模块具有长距离、高速率两种传输模式,一个主机(协调器)支持多达200个节点与其通讯&#xff0…

IMX6ULL学习整理篇——UBoot的一些基础知识(1.编译流程)

前言 笔者整理了最近刷IMX6ULL的一些学习笔记,这里打算稍微整理一下东西发上来作为作为一个补充 正文 大部分而言,当我们拿到源码的时候,一般都是——先使用make来生成一份针对我们目标开发板的配置。举个例子,正点原子针对他们…

docker桌面版启动redis,解决无法连接

docker run -d --name redis -p 6379:6379 -v E:\2\redis\redis.conf:/usr/local/etc/redis/redis.conf redis redis-server /usr/local/etc/redis/redis.conf 在本地创建一个目录,里面有个redis.conf文件,内容如下,启动时绑定这个配置文件目…

2025-03-15 学习记录--C/C++-PTA 习题3-3 出租车计价

合抱之木,生于毫末;九层之台,起于累土;千里之行,始于足下。💪🏻 一、题目描述 ⭐️ 习题3-3 出租车计价 本题要求根据某城市普通出租车收费标准编写程序进行车费计算。具体标准如下&#xff1…

《C++ Primer》学习笔记(二)

第二部分:C标准库 1.为了支持不同种类的IO处理操作,标准库定义了以下类型的IO,分别定义在三个独立的文件中:iostream文件中定义了用于读写流的基本类型;fstream文件中定义了读写命名文件的类型;sstream文件…

数据类设计_图片类设计之6_混合图形类设计(前端架构)

前言 学的东西多了,要想办法用出来.C和C是偏向底层的语言,直接与数据打交道.尝试做一些和数据方面相关的内容 引入 接续上一篇,讨论混合图形类设计 方法论-现在能做什么 这段属于聊天内容---有句话是这么说的:不要只埋头拉车,还要抬头看路。写代码也是…

招聘信息|基于SprinBoot+vue的招聘信息管理系统(源码+数据库+文档)

招聘信息管理系统 目录 基于SprinBootvue的招聘信息管理系统 一、前言 二、系统设计 三、系统功能设计 5.1系统功能模块 5.2管理员功能模块 5.3企业后台管理模块 5.4用户后台管理模块 四、数据库设计 五、核心代码 六、论文参考 七、最新计算机毕设选题推荐 八、…

【软件】免费的PDF全文翻译软件,能保留公式图表的样式

转载请注明出处:小锋学长生活大爆炸[xfxuezhagn.cn] 如果本文帮助到了你,欢迎[点赞、收藏、关注]哦~ 很多PDF全文翻译软件都是收费的,而划线翻译看着又很累。这个开源的PDF全文翻译软件非常好用,并且能够保留公式、图表、目录和注…

79.HarmonyOS NEXT 手势操作模型详解:移动、缩放与旋转的实现原理

温馨提示:本篇博客的详细代码已发布到 git : https://gitcode.com/nutpi/HarmonyosNext 可以下载运行哦! HarmonyOS NEXT 手势操作模型详解:移动、缩放与旋转的实现原理 文章目录 HarmonyOS NEXT 手势操作模型详解:移动、缩放与旋…

解读Ant Design X API流式响应和流式渲染的原理

前言 AI是未来世界的趋势,deepseek的出现让在国内构建更多的大模型出现了更多的可能。而从前端出发,Ant design团队最近很有意思,基于这个背景,提供了一套面向构建平台化产品的组件。 本篇结合Ant design AI的XSteam、XRequesta…

CentOS 7 64 安装 Docker

前言 在虚拟机中安装 Docker 是一种常见的测试和开发环境搭建方式。通过在虚拟机上安装 Docker,可以方便地创建和管理容器化应用,同时避免对宿主机系统造成影响。以下是在 CentOS 7 虚拟机中安装 Docker 的详细步骤。 1. 更新系统(可以不操作…

SPI驱动(八) -- SPI_DAC设备驱动程序

文章目录 参考资料:一、编写设备树二、 编写驱动程序三、编写测试APP四、Makefile五、上机实验 参考资料: 参考资料: 内核头文件:include\linux\spi\spi.h内核文档:Documentation\spi\spidevDAC芯片手册:…

Ansible 自动化运维

Ansible架构: 一.部署主机清单 前期环境准备: 管理端: 192.168.60.128 被管理端: client1:192.168.60.129 client2:192.168.60.131 1.所有被管理端配置ssh密钥 (1.免密登陆 2.允许root远程登陆) 脚本如下: #!/bin/bash# 检查 sshpass 是否已安装 if ! command -v ss…