- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
如何在没有 MANIFEST.in 文件的情况下为 sdist
包含 package_data
?
我的 setup.py 看起来像这样:
import setuptools
setuptools.setup(
name='foo',
version='2015.3',
license='commercial',
packages=setuptools.find_packages(),
package_data={'': ['foo/bar.txt']},
)
版本:
user@host> python
Python 2.7.6 (default, Mar 22 2014, 22:59:56)
>>> import setuptools
>>> setuptools.version.__version__
'3.6'
我就是无法将 foo/bar.txt
包含在内。
或者是this blog post尚真? http://blog.codekills.net/2011/07/15/lies,-more-lies-and-python-packaging-documentation-on--package_data-/
不过,在过去的一个小时里,我了解到这些陈述介于“危险的误导”和“该死的谎言”之间。这是因为 Python 包的主要类型是源码包,而创建源码包的规范方法是使用 setup.py sdist
。但是,在 package_data 中指定的数据不包含在源代码分发中——它们只包含在二进制 (setup.py bdist
) 分发和安装 (setup.py install
) 中。
如何在没有 MANIFEST.in 文件的情况下为 sdist
包含 package_data
?
最佳答案
TL;DR:package_data
字典中的键是packages;这些值是 glob 列表。 ''
不是任何 Python 包的有效名称。
如果你想让 bar.txt
安装在 foo
包的 __init__.py
旁边,请使用
package_data={'foo': ['bar.txt']}
我有布局:
foo/
__init__.py
bar.txt
setup.py
现在,如果 foo
是像上面这样的包,那么:
import setuptools
setuptools.setup(
name='foo',
version='2015.3',
license='commercial',
packages=setuptools.find_packages(),
package_data={'foo': ['bar.txt']},
)
在python setup.py sdist
之后,我检查dist/foo-2015.3.tar.gz
% tar tfz dist/foo-2015.3.tar.gz
...
foo-2015.3/foo/bar.txt
...
但是,如果我使用 package_data={'': ['foo/bar.txt']}
运行您的 setup.py
,我可以同意 foo/bar.txt
将不会添加到源代码分发中,除非 foo-2015.3.egg-info/SOURCES.txt
已经有 foo/bar.txt
的行 - 在这种情况下,该文件也会在源代码分发中弹出
没有使用 list ; setuptools 版本是 3.6
(我故意安装了与您使用的相同的旧版本):
>>> import setuptools
>>> setuptools.__version__
'3.6'
上述行为也适用于标准 distutils
:2.6 Installing package data “遗留”的 distutils 文档;对 2.7、3.1 发表评论:
Changed in version [2.7, 3.1]: All the files that match
package_data
will be added to theMANIFEST
file if no template is provided.
关于python - 如何在没有 MANIFEST.in 文件的情况下包含 package_data?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29036937/
我是 Java 新手,这是我的代码, if( a.name == b.name && a.displayname == b.displayname && a.linknam
在下面的场景中,我有一个 bool 值。根据结果,我调用完全相同的函数,唯一的区别是参数的数量。 var myBoolean = ... if (myBoolean) { retrieve
我是一名研究 C++ 的 C 开发人员: 我是否正确理解如果我抛出异常然后堆栈将展开直到找到第一个异常处理程序?是否可以在不展开的情况下在任何 throw 上打开调试器(即不离开声明它的范围或任何更高
在修复庞大代码库中的错误时,我观察到一个奇怪的情况,其中引用的动态类型从原始 Derived 类型更改为 Base 类型!我提供了最少的代码来解释问题: struct Base { // some
我正在尝试用 C# 扩展给定的代码,但由于缺乏编程经验,我有点陷入困境。 使用 Visual Studio 社区,我尝试通过控制台读出 CPU 核心温度。该代码使用开关/外壳来查找传感器的特定名称(即
这可能是一个哲学问题。 假设您正在向页面发出 AJAX 请求(这是使用 Prototype): new Ajax.Request('target.asp', { method:"post", pa
我有以下 HTML 代码,我无法在所有浏览器中正常工作: 我试图在移动到
我对 Swift 很陌生。我如何从 addPin 函数中检索注释并能够在我的 addLocation 操作 (buttonPressed) 中使用它。我正在尝试使用压力触摸在 map 上添加图钉,在两
我设置了一个详细 View ,我是否有几个 Nib 文件根据在 Root View Controller 的表中选择的项目来加载。 我发现,对于 Nibs 的类,永远不会调用 viewDidUnloa
我需要动态访问 json 文件并使用以下代码。在本例中,“bpicsel”和“temp”是变量。最终结果类似于“data[0].extit1” var title="data["+bpicsel+"]
我需要使用第三方 WCF 服务。我已经在我的证书存储中配置了所需的证书,但是在调用 WCF 服务时出现以下异常。 向 https://XXXX.com/AHSharedServices/Custome
在几个 SO 答案(1、2)中,建议如果存在冲突则不应触发 INSERT 触发器,ON CONFLICT DO NOTHING 在触发语句中。也许我理解错了,但在我的实验中似乎并非如此。 这是我的 S
如果进行修改,则会给出org.hibernate.NonUniqueObjectException。在我的 BidderBO 类(class)中 @Override @Transactional(pr
我使用 indexOf() 方法来精细地查找数组中的对象。 直到此刻我查了一些资料,发现代码应该无法正常工作。 我在reducer中尝试了上面的代码,它成功了 let tmp = state.find
假设我有以下表格: CREATE TABLE Game ( GameID INT UNSIGNED NOT NULL, GameType TINYINT UNSIGNED NOT NU
代码: Alamofire.request(URL(string: imageUrl)!).downloadProgress(closure: { (progress) in
我是一名优秀的程序员,十分优秀!