不幸的是,两者都没有distutils
nor setuptools
提供了排除单个模块的可能性,因此您必须解决它。
Update:
我描述了一个更好的解决方案here模仿包排除setuptools
确实在find_packages()
。你必须覆盖build_py
设置脚本中的命令可以接受排除模式列表,与exclude
列出在find_packages
。在你的情况下,它将是:
import fnmatch
from setuptools import find_packages, setup
from setuptools.command.build_py import build_py as build_py_orig
exclude = ['src.file_to_exclude']
class build_py(build_py_orig):
def find_package_modules(self, package, package_dir):
modules = super().find_package_modules(package, package_dir)
return [(pkg, mod, file, ) for (pkg, mod, file, ) in modules
if not any(fnmatch.fnmatchcase(pkg + '.' + mod, pat=pattern)
for pattern in exclude)]
setup(
...,
packages=find_packages(),
cmdclass={'build_py': build_py},
)
我发现这是一个更强大的distutils
- 与以下解决方案一致。它还允许通过通配符匹配排除多个模块,例如
exclude = ['src.file*']
将排除以以下开头的所有模块file
in src
包,或
exclude = ['*.file1']
将排除file1.py
在所有包中。
原答案
将要排除的模块放在单独的包中
你可以利用这样一个事实setuptools
可以排除包(包含__init__.py
文件),但这需要一些重构。创建一个package_to_exclude
, put file_to_exclude.py
在那里修复所有最终的导入错误:
project
├── setup.py
└── src
├── __init__.py
├── file1.py
├── file2.py
└── package_to_exclude
├── __init__.py
└── file_to_exclude.py
现在您可以排除package_to_exclude
在设置脚本中:
from setuptools import find_packages, setup
setup(
...,
packages=find_packages(exclude=['src.package_to_exclude'])
)
排除包,添加要包含的模块py_modules
如果您不能或不想将模块移动到单独的包中,则可以排除src
打包并添加所有模块src
except file_to_exclude
in py_modules
。例子:
import os
from setuptools import find_packages, setup
excluded_files = ['file_to_exclude.py']
included_modules = ['src.' + os.path.splitext(f)[0]
for f in os.listdir('src')
if f not in excluded_files]
setup(
...,
packages=find_packages(exclude=['src']),
py_modules=included_modules,
)