python构建并发布自己的包

一、背景

我们平时使用pip install xxx安装包,使用包,但是如果:我们拉取pypi社区的某GitHub项目源码后,发现其源码某文件中会出现:

py 复制代码
import xxx.module_A
from xxx import module_A
import xxx.module_A as A
from xxx import module_A as A

这种字样

注意 :这里的xxx是某文件所在目录的包名,也就是其所属包的名字

注意:不可以直接导入包,python是一定要落脚于模块的

那么直接运行源码,会出现依赖的问题;如何解决这个问题,是本博客解决的事情

类似于下图的依赖过程:

tool.py依赖my_module.py时,平时都是直接引入模块名,但是在发布后的包中,会出现import my_package.my_module as my_module

和我们认知中不一样,并且直接运行这个脚本会出错:

所以我们需要搞清楚这个包为什么这样引入

二、实验过程

包的文件结构:

注意 :实际的包是my_package,而不是这个项目

与第一部分一样,tool依赖了my_module

使用时的测试代码:

py 复制代码
import my_package.tool as tool

if __name__ == "__main__":
    print("hello world")
    tool.my_tool()

构建包

在项目目录下(而不是实际的包目录下),新建setup.py文件:

py 复制代码
from setuptools import setup, find_packages

VERSION = '0.0.1' 
DESCRIPTION = 'My first Python package'
LONG_DESCRIPTION = 'My first Python package with a slightly longer description'

# 配置
setup(
       # 名称必须匹配文件名 'verysimplemodule'
        name="my_package", 
        version=VERSION,
        author="masteryi",
        author_email="<youremail@email.com>",
        description=DESCRIPTION,
        long_description=LONG_DESCRIPTION,
        packages=find_packages(),
        install_requires=[], # add any additional packages that 
        # 需要和你的包一起安装,例如:'caer'
        
        keywords=['python', 'first package'],
        classifiers= [
            "Development Status :: 3 - Alpha",
            "Intended Audience :: Education",
            "Programming Language :: Python :: 2",
            "Programming Language :: Python :: 3",
            "Operating System :: MacOS :: MacOS X",
            "Operating System :: Microsoft :: Windows",
        ]
)

测试包

执行python setup.py install

本地安装自己写的包:

成功安装:

在测试文件测试,成功输出:

shell 复制代码
PS D:\project\test_my_pkg> python .\test.py
hello world
this is my_module
this is sub_pkg's m_1
this is sub_pkg's m_2

三、心得

构建包的话,各个模块需要统一引入包名作为所构建包的名称,子包也是一样的处理,否则会出现找不到包的问题

如果按照自己的构建项目的方式构建包,就会出现包的路径有问题的情况

参考资料

相关推荐
IT毕设梦工厂4 分钟前
计算机毕业设计选题推荐-岗位招聘数据可视化分析-Python爬虫
python·django·毕业设计·源码·课程设计·数据可视化
乔丹搞IT8 分钟前
解读FastAPI异步化为transformers模型打造高性能接口解析
python·fastapi
麻辣香蝈蝈10 分钟前
【Java】微服务Knife4j报错503问题 网关整合解决
java·开发语言·spring boot·spring cloud·微服务·knife4j
lianyinghhh26 分钟前
Java设计模式【享元模式】-结构型
java·开发语言·设计模式
CS_木成河28 分钟前
【HuggingFace Transformers】BertIntermediate 和 BertPooler源码解析
人工智能·python·深度学习·大模型·bert·transformer
爱写bug的小刘29 分钟前
16、CPU缓存架构
java·开发语言·后端·缓存
箬敏伊儿29 分钟前
Java-Springfox介绍及使用教程
java·开发语言·spring boot·spring·maven
friklogff41 分钟前
【Rust光年纪】提供安全执行环境,防止内存泄漏和非授权访问
开发语言·安全·rust
zhangbin_23742 分钟前
【Python机器学习】NLP分词——利用分词器构建词汇表(四)——标点符号的处理
开发语言·人工智能·python·机器学习·自然语言处理·机器人
@我们的天空1 小时前
【人工智能】项目案例分析:使用深度强化学习玩《吃豆人》游戏
人工智能·pytorch·python·神经网络·游戏·机器学习·tensorflow