048.Python包和模块_发布包和模块

无奋斗不青春

我 的 个 人 主 页:👉👉 失心疯的个人主页 👈👈
入 门 教 程 推 荐 :👉👉 Python零基础入门教程合集 👈👈
虚 拟 环 境 搭 建 :👉👉 Python项目虚拟环境(超详细讲解) 👈👈
PyQt5 系 列 教 程:👉👉 Python GUI(PyQt5)文章合集 👈👈
Oracle数据库教程:👉👉 Oracle数据库文章合集 👈👈
优 质 资 源 下 载 :👉👉 资源下载合集 👈👈

分隔线

发布包和模块

    • 发布包和模块
      • 文档地址
      • 账号操作
      • 环境准备
      • 发布前准备
        • 创建一个项目
          • 命名规则
          • 项目解析
        • 编译生成发布包
        • 安装编译的发布包
      • 发布过程
      • 发布后使用

发布包和模块

文档地址

  • 发布包和模块的详细说明
  • https://python-packaging.readthedocs.io/en/latest/minimal.html

账号操作

  • 注册账号:https://pypi.org/account/register/
  • 账号:FengZi2023
  • 邮箱:860205500@qq.com

环境准备

  • setuptools安装
    • 将所写的代码打包成源码和.egg格式
  • wheel安装
    • 将所写的代码打包成.whl格式
    pip install wheel# 安装到指定版本python环境
    python -m pip install wheel
    
  • twine安装
    • 快速发布本地已经打包成不同格式的包和模块到pypi平台
    pip install twine
    
  • pip
    • 测试上传的包和模块

发布前准备

创建一个项目
命名规则
  • 全部小写
  • 多个单词以中划线"-“作为分割,不要使用下划线”_",pip安装队下划线支持部是很好
  • 不能和PyPi平台上已有的包名称重复
项目解析
  • 项目结构

    项目名称包名称__init__.py模块模块setup.pyREADME.rstLICENSE.txtMANIFEST.in# setup.py 项目信息的配置文件
    # 这里面最重要的就是执行一个setup函数,通过这个函数来指明信息
    from distutils.core import setup
    setup(形参1=实参1, 形参2=实参2)# 建议使用
    from setuptools import setup
    setup(形参1=实参1, 形参2=实参2)
    
  • 示例

  • 在这里插入图片描述

  • fzlibone.py文件代码

    def run():print('fzlibone----run')
    
  • __init__.py文件代码

    # 使用户通过import fztestlib 导入包,能调用fzlibone.py内部资源
    # import导入包的时候会自动调用__init__.py文件代码from . import fzlibone
    
  • Tool.py文件代码

    def test():print('Tool----test')
    
  • setup.py文件代码

    # from distutils.core import setup
    from setuptools import setup
    setup(name="fztestlib", version="1.0.0",description="this is a niubi lib",packages=["fztestlib"], py_modules=["Tool"], author='FZ', author_email="860205500@qq.com",long_description="this is a hen long hen long lib", url="https://www.baidu.com")
    
    • setup.py参数说明
    • 详细文档说明:https://packaging.python.org/en/latest/tutorials/packaging-projects/
    # -----必填选项-----
    # name                  # 包名称(如:name = "fztestlib")
    # version               # 包版本(如:version="1.0.0")
    # description           # 描述信息(如:description="this is a very niubi lib")
    # packages              # 需要处理的包列表(如:packages=["fztestlib"])# 这里是告诉打包工具要将哪些子包打包到整个大包里面# -----非必填选项-----
    # py_modules            # 需要处理的单文件模块列表(如:py_modules=["Tool"])
    # author                # 作者(如:author="FZ")
    # author_email          # 作者邮箱(author_email="860205500@qq.com")
    # long_description      # 长描述,会显示在PyPi平台的项目介绍中# 如:long_description="这里的字符串是可以从readme.rst文件中读取进来的"
    # install_requires      # 依赖的其他包(如:install_requires=["requests>2.29"])
    # python_requires       # Python版本限制(如:python_requires=">=3")
    # url                   # 项目主页地址(如:url="https://...")
    # license               # 协议(如:license="MIT")
    .
    .
    .
    
  • 文件打包

    1、打开命令行工具(cmd),进入到项目目录
    2、输入打包命令:python setup.py sdist
    # 个人理解:使用python执行setup.py文件,创建一个源码编译包
    # 这里打包出来的是源码文件压缩包,可以直接上传到PyPi平台
    # 最终打包出来的包名称由setup.py中的name和version通过一个“-”拼接而成
    # 打包时包含的文件有setup.py文件中的packages和py_modules两个参数设定(包 和 单文件模块)
    
    • 在这里插入图片描述
  • 其他可选文件说明

  • README.rst 文件

    • 具体语法文档说明:https://zh-sphinx-doc.readthedocs.io/en/latest/rest.html
    #     rst:reStructuredText,重新构建的文本
    # 作   用:# 可以使用特定的字符,来描述文本的格式# PyPi平台能够自动识别long_description字段中缩写的这种格式的字符串# 如果全部写到setup.py文件的setup函数的参数中,会比较混乱# 一般会将内容单独写到一个README.rst文件中# 然后在setup.py文件中读取这个内容,并赋值给long_description参数即可
    # 语法格式# 具体语法文档说明:https://zh-sphinx-doc.readthedocs.io/en/latest/contents.html# 建议使用PyCharm编辑,内部安装了一个支持.rst文件的插件,能自动识别rst语法格式# 插件:settings —— plugins —— ReStructuredText# 如果没有,则手动安装一下
    # 语法检测(截止当前学习的时候202312,PyCharm会直接显示.rst文件效果)# 检测rst文件中的内容,在PyPi平台上是否能正常显示# 我们正常是参照sphinx解析器,但是Pypi平台对于rst的解析器并不是sphinx# 所以,会导致部分语法有一些差异# 解决方案:通过readme_renderer库从本地对long_description进行验证# 安装库:pip install readme_renderer# 执行命令:python setup.py check -r -s# -r:检测文件是否符合ReStructuredText语法# -s:如果不符合,则退出# 如果符合则输出:running check
    
    • PyCharm中README.rst文件中文显示乱码问题解决
      • 在这里插入图片描述

      • 在这里插入图片描述

      • Help —— Edit Custom VM Options… —— 添加一行

      -Dfile.encoding=UTF-8
      
      • 重启PyCharm
  • LICEBSE.txt 文件

    • 开源协议获取地址:https://choosealicense.com
    # 作用:声明库的一些使用责任等
    # 比如:所有权归属;别人是否可以对代码进行任何操作;是否可以用于其他商业用途等
    # 开源协议获取地址:https://choosealicense.com
    # 可以到开源协议网址内复制协议内容粘贴到LICEBSE.txt文件中
  • MANIFEST.in 文件

    # 作用:# 当我们打包一个项目的时候,并非所有的文件都会被默认打包在目标包中# 打包工具最终会把所有已经打包的文件生成一个MANIFEST文件的列表# 我们就可以通过MANIFEST.in文件告诉打包工具,让其新增一些指定文件
    # 具体官方文档# 语法格式# include 文件名全名(含后缀)                    # 添加导入指定文件# include *.txt                                 # 添加导入指定类型的文件# recursive-include examples *.txt *.py         # 递归查询指定文件夹examples内所有子文件夹中指定类型的文件# prune examples/sample?/build                  # 屏蔽指定文件夹build内的所有文件
    
编译生成发布包
  • 编译语法
    # cmd命令行工具,进入到setup.py所在目录# 查看所有命令
    python setup.py --help-commands# 生成源码压缩包
    python setup.py sdist
    # 包含setup.py、模块源文件、数据文件等,可以用在任何平台上重新编译所有内容
    # --formats = 压缩格式1, 压缩格式2(zip、tar、gztar、bztar、xztar、ztar)# 生成二进制发行包
    python setup.py bdist
    # 不包含setup.py文件,是某个特定平台和Python版本的一个存档# 生成一个编译后的egg格式发行包
    python setup.py bdist_egg
    # python环境必须安装setuptools库# 生成一个编译后的whl格式发行包
    python setup.py bdist_wheel
    # python环境必须安装wheel库# 生成一个windows系统可执行安装的发行包
    python setup.py bdist_wininst
    
    • 在这里插入图片描述
安装编译的发布包
  • 安装带setup.py源码压缩包
    • 方式一
      1、解压压缩包
      2、cmd进入到setup.py文件所在目录
      3、执行python setup.py install
      
    • 方式二
      pip install 压缩包
      
    • 方式三
      easy_install 压缩包
      
  • 安装二进制发行包
    • 解压后直接拷贝到指定目录
  • 通过windows下的安装文件安装
    • 直接双击exe文件进行安装
  • 安装.egg格式发行包
    easy_install xxx.egg
    
  • 安装.whl格式发行包
    easy_install xxx.whlpip install xxx.whl
    

发布过程

  • 注意:Python环境需要安装twine库
  • 上传带setup.py文件的源码压缩包
    twine upload 源码压缩包# 这里上传的时候需要输入前面注册的账号和密码
    # 现在上传必须启用双因素身份验证
    WARNING  Error during upload. Retry with the --verbose option for more details.
    ERROR    HTTPError: 403 Forbidden from https://upload.pypi.org/legacy/You must enable two factor authentication to upload
    

发布后使用

  • 详见上面包安装操作

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

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

相关文章

ARM工控机Node-red使用教程

嵌入式ARM工控机Node-red安装教程 从前车马很慢书信很远,而现在人们不停探索“科技改变生活”。 智能终端的出现改变了我们的生活方式,钡铼技术嵌入式工控机协助您灵活布建能源管理、大楼自动化、工业自动化、电动车充电站等各种多元性IoT应用&#xff…

Unity组件开发--UI管理器

1.Canvas组件: 注意属性: (1)渲染模式是:屏幕空间相机 (2)创建一个UICamera节点,管理相机 (3)屏幕画布缩放模式 (4)画布下挂载两…

前端项目构建打包生成Git信息文件

系列文章目录 TypeScript 从入门到进阶专栏 文章目录 系列文章目录前言一、前端项目构建打包生成Git信息文件作用二、步骤1.引入相关的npm包1.1. **fs** 包1.2. **child_process** 包1.3. **os** 包 (非必须 如果你想生成的文件信息中包含当前电脑信息则可用)1.4. **path** 包…

基于宝塔搭建Discuz!论坛

一、安装宝塔 我是在我的虚拟机上安装图的宝塔 虚拟机版本:Ubuntu 18.04 wget -O install.sh https://download.bt.cn/install/install-ubuntu_6.0.sh && sudo bash install.sh 6dca892c安装完成之后在浏览器输入你的地址 https://你的域名(或…

每天刷两道题——第十一天

1.1滑动窗口最大值 给你一个整数数组 nums,有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧。你只可以看到在滑动窗口内的 k 个数字。滑动窗口每次只向右移动一位。返回滑动窗口中的最大值 。 输入:nums [1,3,-1,-3,5,3,6,7], k 3 输出&…

面试题-DAG 有向无环图

有向无环图用于解决前后依赖问题,在Apollo中用于各个组件的依赖管理。 在算法面试中,有很多相关题目 比如排课问题,有先修课比如启动问题,需要先启动1,才能启动2 概念 顶点: 图中的一个点,比…

k8s 之7大CNI 网络插件

一、介绍 网络架构是Kubernetes中较为复杂、让很多用户头疼的方面之一。Kubernetes网络模型本身对某些特定的网络功能有一定要求,但在实现方面也具有一定的灵活性。因此,业界已有不少不同的网络方案,来满足特定的环境和要求。 CNI意为容器网络…

C# Entity Framework 中不同的数据的加载方式

延迟加载 延迟加载是指在访问导航属性时,Entity Framework 会自动查询数据库并加载相关数据。这种方式在我们需要访问导航属性时比较方便,因为我们无需手动加载相关数据,而且只会在需要时才会进行查询,从而减少了不必要的开销。但…

模仿Activiti工作流自动建表机制,实现Springboot项目启动后自动创建多表关联的数据库与表的方案

文/朱季谦 熬夜写完,尚有不足,但仍在努力学习与总结中,而您的点赞与关注,是对我最大的鼓励! 在一些本地化项目开发当中,存在这样一种需求,即开发完成的项目,在第一次部署启动时&…

C++笔记之cout高亮输出以及纯C++实现一个彩色时钟

C笔记之cout高亮输出以及纯C实现一个彩色时钟 code review! 文章目录 C笔记之cout高亮输出以及纯C实现一个彩色时钟一.cout高亮输出1.1.运行1.2.代码一1.3.代码二1.4.重置终端的文本格式到默认设置说明 二.纯C实现一个彩色时钟2.1.运行2.2.main.cc2.3.cout带颜色打印输出技巧…

springCould中的Bus-从小白开始【11】

目录 🧂1.Bus是什么❤️❤️❤️ 🌭2.什么是总线❤️❤️❤️ 🥓3.rabbitmq❤️❤️❤️ 🥞4.新建模块3366❤️❤️❤️ 🍳5.设计思想 ❤️❤️❤️ 🍿6.添加消息总线的支持❤️❤️❤️ &#x1f9…

图解Kubernetes的服务(Service)

pod 准备: 不要直接使用和管理Pods: 当使用ReplicaSet水平扩展scale时,Pods可能被terminated当使用Deployment时,去更新Docker Image Version,旧Pods会被terminated,然后创建新Pods 0 啥是服务&#xf…

OCS2 入门教程(四)- 机器人示例

系列文章目录 前言 OCS2 包含多个机器人示例。我们在此简要讨论每个示例的主要特点。 System State Dim. Input Dim. Constrained Caching Double Integrator 2 1 No No Cartpole 4 1 Yes No Ballbot 10 3 No No Quadrotor 12 4 No No Mobile Manipul…

【java爬虫】首页显示沪深300指数走势图以及前后端整合部署方法

添加首页 本文我们将在首页添加沪深300指数成立以来的整体走势数据展示,最后的效果是这样的 单独贴一张沪深300整体走势图 我感觉从总体上来看指数还是比较稳的,没有特别大的波动,当然,这只是相对而言哈哈。 首先是前端页面 &l…

【python】内存管理和数据类型问题

一、内存管理 Python有一个自动内存管理机制,但它并不总是按照期望的方式工作。例如,如果创建了一个大的列表或字典,并且没有删除它,那么这个对象就会一直占用内存,直到Python的垃圾回收器决定清理它。为了避免这种情…

Android开发基础(一)

Android开发基础(一) 本篇主要是从Android系统架构理解Android开发。 Android系统架构 Android系统的架构采用了分层的架构,共分为五层,从高到低分别是Android应用层(System Apps)、Android应用框架层&a…

二线厂商-线上测评-大数据开发

曾经投递过一些中级岗位,在面试之前,会通过邮件的方式把性格测试的题目发给你让你做一下。 一般分为单选题,多选题,性格测试题,认知理解题等等。 大概做了一个小时吧。 单选题: 感觉就是类似于以前高中时候…

前缀和--二维矩阵的前缀和

目录 子矩阵的和思路:代码: 原题链接 子矩阵的和 输入一个 n 行 m 列的整数矩阵,再输入 q 个询问,每个询问包含四个整数 x1,y1,x2,y2 ,表示一个子矩阵的左上角坐标和右下角坐标。 对于每个询问输出子矩阵中所有数的和…

C#入门篇(一)

变量 顾名思义就是变化的容器,即可以用来存放各种不同类型数值的一个容器 折叠代码 第一步:#region 第二步:按tab键 14种数据类型 有符号的数据类型 sbyte:-128~127 short:-32768~32767 int:-21亿多~21亿多…

Windows 双网卡链路聚合解决方案

Windows 双网卡链路聚合解决方案 链路聚合方案1:Metric介绍操作 方案2:NetSwitchTeam介绍操作 方案3:NIC介绍操作 方案4:Intel PROSet 链路聚合 指将多个物理端口汇聚在一起,形成一个逻辑端口,以实现出/入…