Skip to main content

将Python文件转换为pyd/so文件的工具

Project description

Python转pyd/so工具

这个工具用于将Python文件(.py)转换为编译后的Python扩展模块(.pyd或.so),使用Cython进行编译。

功能特点

  • 支持单个Python文件的转换
  • 支持目录批量转换
  • 支持递归处理子目录
  • 转换后可选择是否删除原始Python文件
  • 保留__init__.py文件内容处理
  • 自动检测依赖并提供错误处理
  • 针对不同操作系统自动选择正确的扩展名(Windows为.pyd,Linux/MacOS为.so)
  • 优化编译选项,消除常见警告信息

安装依赖

在使用此工具前,请确保已安装以下依赖:

pip install cython loguru

此外,你的系统需要有合适的C/C++编译器:

  • Windows: 需要安装Visual C++ Build Tools
  • Linux: 需要安装GCC
  • macOS: 需要安装XCode命令行工具(xcode-select --install

使用方法

1. 转换单个文件

python py2pyd.py path/to/your/file.py

2. 转换目录下所有Python文件

python py2pyd.py path/to/your/directory

3. 递归转换目录及其子目录中的所有Python文件

python py2pyd.py -r path/to/your/directory

4. 转换后删除原始Python文件

python py2pyd.py --remove path/to/your/file.py

5. 全部选项组合

python py2pyd.py -r --remove path/to/your/directory

作为模块导入

你也可以在自己的Python代码中导入该模块:

# 转换单个文件
from module.single_py2pyd import py2pyd
success = py2pyd('path/to/your/file.py')
if success:
    print("转换成功")
else:
    print("转换失败")

# 转换整个目录
from module.fileConversion import FileConversion
converter = FileConversion()
success = converter.get_all_file('path/to/your/directory', need_remove=False)
print(f"成功:{converter.success_count} 个文件,失败:{converter.fail_count} 个文件")

错误处理

工具会自动检测必要的依赖并提供错误信息。常见问题包括:

  1. 缺少Cython: 运行前会检查Cython是否已安装,若未安装则会提示安装。
  2. 编译失败: 如果编译失败,会提供详细错误信息,可能是缺少编译器或者Python文件内容有问题。

优化的编译选项

本工具针对不同操作系统和环境进行了编译选项优化:

  1. 设置语言级别: 显式设置Cython的language_level为3,避免语言级别警告
  2. 禁止无用代码警告: 添加适当的编译选项(-Wno-unreachable-code)以禁止Cython生成的C代码中的不可达代码警告
  3. 修复Conda/Miniconda链接警告: 在Conda环境中自动调整链接选项,避免重复的rpath警告

注意事项

  • 确保已安装Cython和适当的编译器
  • 转换后的so/pyd文件会保留在原始Python文件的相同目录中
  • 在Windows系统上生成.pyd文件,在Linux/MacOS上生成.so文件
  • 对于复杂的Python项目,可能需要额外的编译选项

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

gl_py2pyd-0.1.0.tar.gz (6.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

gl_py2pyd-0.1.0-py3-none-any.whl (7.6 kB view details)

Uploaded Python 3

File details

Details for the file gl_py2pyd-0.1.0.tar.gz.

File metadata

  • Download URL: gl_py2pyd-0.1.0.tar.gz
  • Upload date:
  • Size: 6.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.7

File hashes

Hashes for gl_py2pyd-0.1.0.tar.gz
Algorithm Hash digest
SHA256 53d47eb1f7ba4483330183cc9aec9c2eb574d21c352443b708c08c4a1af0e077
MD5 b0817262128cb6fe1cfeb526ea4d032c
BLAKE2b-256 78ce4ec11abffe45f77ba9425b1c1d30d1d3983f454457d91ea72ce7f0809fe0

See more details on using hashes here.

File details

Details for the file gl_py2pyd-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: gl_py2pyd-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 7.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.7

File hashes

Hashes for gl_py2pyd-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 010a0509e943d7017599c3ef99263588ea96a61dc908d635da2ec254b0e14734
MD5 b0e90e9a9f194e2ce5199ab12065d803
BLAKE2b-256 171e6b836571104c320b8579ce4b6c25724c28b349829d95db055c710f9c36eb

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page