如何制作自己的python .whl包(支持entry_points)

目录

代码目录结构如下截图所示:

dir_test.py 源码如下:

复制代码
import os
import sys
from pathlib import Path

def show():
    print(f"---->>>> king ca...")

def current_file() -> str:
    return os.path.realpath(__file__)

def current_dir() -> str:
    return os.path.dirname(current_file())

def set_python_path():
    root = Path(current_dir())
    sys.path.append(str(root)) #主要是这个函数来解决相对路径问题

def run():
    from list.dir_list import list_dir_contents #这行代码也很重要,不能放到code最前面,要确保在set_python_path()之后执行
    current_directory = os.getcwd()
    print(f"当前目录: {current_directory}")

    # 示例:列出当前目录及其所有子目录的内容
    print("\n列出当前目录及其子目录的所有内容:")
    list_dir_contents(current_directory)

    # 示例:只列出文件
    print("\n只列出文件:")
    list_dir_contents(current_directory, is_file_only=True)

    # 示例:只列出目录
    print("\n只列出目录:")
    list_dir_contents(current_directory, is_dir_only=True)

    show()

def main():
    set_python_path() #这个很关键,否则运行时会找不到自己py工程子目录下的py模块
    run()

if __name__ == "__main__":
    main()

list/dir_list.py 源码如下:

复制代码
import os

def list_dir_contents(startpath, indent=0, is_file_only=False, is_dir_only=False):
    """
    递归地列出目录内容。

    :param startpath: 开始列出的目录路径。
    :param indent: 缩进级别,用于递归时显示层级结构。
    :param is_file_only: 如果为True,则只列出文件。
    :param is_dir_only: 如果为True,则只列出目录。
    """
    if is_file_only and is_dir_only:
        print("不能同时只列出文件和只列出目录。")
        return

    for root, dirs, files in os.walk(startpath):
        level = root.replace(startpath, '').count(os.sep)
        indent_str = '    ' * (indent + level)
        subindent = '    ' * indent

        if not is_file_only:
            for dir in dirs:
                print(f"{indent_str}[D] {dir}")

        if not is_dir_only:
            for file in files:
                print(f"{indent_str}[F] {file}")

        # 递归调用以列出子目录的内容(如果需要的话)
        # 注意:这里我们没有增加indent,因为每个新的os.walk循环已经处理了缩进
        # 但你可以根据需要调整indent参数来改变缩进级别

setup.py 文件源码

复制代码
from setuptools import setup, find_packages

setup(
    name='ax_dirtest',
    version='0.9.9',
    packages=find_packages(),
    install_requires=[
        # 这里列出你的包依赖项
    ],
    include_package_data=True,
    entry_points={
        'console_scripts': [
            'ax_dirtest = ax_dirtest.dir_test:main',
        ],
    },
)

整个工程代码压缩包:

注意:

  1. 每个子目录下,均需要加一个__init__.py文件,哪怕里面没内容,也需要加上。因为打包成.whl文件时,会判断目录下是否有__init__.py文件,有才会去打包这个目录下的.py文件;
  2. 若要打包其他数据文件(非.py文件),需要在setup.py同级目录增加一个MANIFEST.in文件,文件内容书写格式自行百度(例如后续.exe图标可以以这个形式增加);
  3. 上述工程code安装后,使用者能够看到源码,后续需要完善一下。

生成.whl文件指令:

复制代码
python setup.py bdist_wheel

生成的.whl文件在dist目录下

相关推荐
万粉变现经纪人4 分钟前
如何解决 pip install -r requirements.txt 无效可编辑项 ‘e .‘(-e 拼写错误)问题
开发语言·python·r语言·beautifulsoup·pandas·pip·scipy
say_fall20 分钟前
精通C语言(2.结构体)(内含彩虹)
c语言·开发语言·windows
潇凝子潇20 分钟前
在使用Nacos作为注册中心和配置中心时,如何解决服务发现延迟或配置更新不及时的问题
开发语言·python·服务发现
烛阴22 分钟前
Python 列表推导式:让你的代码更优雅、更高效
前端·python
AI小云26 分钟前
【Python与AI基础】Python编程基础:函数与参数
人工智能·python
长源Gingko31 分钟前
Windows中在QTCreator中调试,提示缺少debug information files问题的解决
windows·qt
white-persist1 小时前
MCP协议深度解析:AI时代的通用连接器
网络·人工智能·windows·爬虫·python·自动化
纵横八荒1 小时前
Java基础加强13-集合框架、Stream流
java·开发语言
codists1 小时前
2025年9月文章一览
python
语落心生1 小时前
FastDeploy SD & Flux 扩散模型边缘端轻量化推理部署实现
python