【问题标题】:How to create a python 2.x package - simple case如何创建 python 2.x 包 - 简单案例
【发布时间】:2010-11-11 15:16:38
【问题描述】:

请展示为 python 2.x 创建 python 包的简单且最新的标准方法

以后我更喜欢使用 pip 来安装包。

包应该包含一个类:

class hello:
  def greet(self):
    print "hello"

以后应该可以做到以下几点:

pip install my_package-0.1.1....

然后使用它:

from my_package import hello

h = hello.hello()
h.greet()

我要的是:

  • 目录和文件布局
  • 文件内容
  • 创建可分发包文件的命令
  • 从可分发包文件安装包的命令(最好使用 pip)

我找到了几个howtos,但我仍然不确定如何处理这个非常简单且精简的案例(没有嵌套包,删除所有文件和功能,对于最简单的案例可以省略),以及哪个是现代的方式。

我希望这个问题进入社区 wiki 状态,所以你不会得到任何分数,我会给予足够的时间,并会在几天后将答案标记为接受,同时考虑投票和 cmets。

编辑:

我想分享第一个正在运行的示例,我使用了 Marius Gedminas 的答案。它不包含应该存在的所有内容,但它确实有效,因此它可以展示技术流程的核心。要添加更多必要的部分,请阅读下面 Marius 的回答。

目录结构:

MyProject/
    setup.py
    my_package.py
    README.txt
    MANIFEST.in

setup.py:

from setuptools.import setup
setup(name='MyProject',
      version='0.1',
      py_modules=['my_package'])

my_package.py:

class hello:
  def greet(self):
    print "hello"

MANIFEST.in:

include *.txt

要从此文件夹创建包,请进入文件夹 MyProject 并运行:

$ python setup.py sdist

这将在子文件夹dist/ 中创建一个文件MyProject-0.1.tar.gz。将此文件复制到目标计算机上的文件夹中。

在目标机器上,在包含MyProject-0.1.tar.gz的文件夹中运行此命令:

sudo pip install MyProject-0.1.tar.gz

现在可能需要在目标机器上注销并重新登录,这样才能找到包。之后,您可以使用 python shell 在目标机器上测试该包:

$ python
>>> import my_package
>>> h = my_package.hello()
>>> h.greet()
hello
>>> 

一旦成功,请记得添加其他必要的内容,请参阅下面 Marius 的回答。

【问题讨论】:

  • 这个问题的重点是选择一种现代方法,然后剥离几乎所有可以剥离的东西,使其仍然有效。

标签: python packaging python-2.x


【解决方案1】:

从简单开始

最简单的一文件包:

MyProject/
    setup.py
    my_package.py

最简单的 setup.py:

from setuptools import setup
setup(name='MyProject',
      version='0.1',
      author='Your Name',
      author_email='your.name@example.com',
      license='MIT',
      description='Example package that says hello',
      py_modules=['my_package'])

在包中包含额外的文件

接下来你可能应该添加一个自述文件:

MyProject/
    MANIFEST.in
    README.rst
    setup.py
    my_package.py

注意新文件 -- MANIFEST.in。它指定哪些非 Python 文件应该包含在您的源代码分发中:

include *.rst

人们会告诉你“哦,跳过清单,只需将文件添加到源代码管理,setuptools 就会找到它们”。忽略这个建议,太容易出错了。

让 PyPI 页面变得有用

让人们可以在 Python 包索引上在线查看 README.rst 很有用。所以改变你的 setup.py 来做

from setuptools import setup
with open('README.rst') as f:
    readme = f.read()
setup(name='MyProject',
      ...
      description='Example package that says hello',
      long_description=readme,
      ...)

对更漂亮的页面使用ReStructuredText 标记。使用

python setup.py --long-description | rst2html

尽早发现 ReStructuredText 错误。

一个包中有多个 Python 模块

一个文件很快就不够用了,所以将其更改为一个包(混淆术语警告:Python 包在带有__init__ py 的目录中,而不是在可分发的自包含存档中):

MyProject/
    MANIFEST.in
    README.rst
    setup.py
    my_package/
        __init__.py
        some_module.py

并将 setup.py 更改为

from setuptools import setup, find_packages
with open('README.rst') as f:
    readme = f.read()
setup(name='MyProject',
      version='0.2',
      author='Your Name',
      author_email='your@email',
      license='MIT',
      description='Example package that says hello',
      long_description=readme,
      packages=find_packages())

向公众发布

Get a PyPI account -- 你只需要这样做一次。

要发布,请确保 setup.py 中的版本号正确,然后运行

python setup.py sdist register upload

就是这样。

告诉人们安装它

告诉他们

pip install MyProject

(与您在 setup.py 中指定的名称与 setup() 的 name 参数相同)

【讨论】:

  • 我在这里弯曲关于“最简单”的问题。虽然我完全同意从简单开始很重要,但最终你需要成长。当这种情况发生时,增长路径应该是清晰的。
  • 我认为您已经在简单和最重要的附加功能之间找到了很好的平衡。
  • “最简单”的方法不是将所有内容都包含在包命名空间中,例如dir/__init__.py?
  • 你的意思是把 init.py 放在项目目录的顶层?我不知道;我从来没有尝试过。它将使设置可以从您的包中导入;我不知道我对此感觉如何。它可能会使测试你的代码而不用更难安装。我更喜欢将可安装的 python 包中的文件与位于该包之外的支持文件分开。
  • setuptools.setuppy_modules参数是什么? pythonhosted.org//setuptools/setuptools.html#developer-s-guide 和帮助内容中没有记录。
【解决方案2】:

以下内容抄自Distutils Tutorial

文件布局:

top
|-- package
|   |-- __init__.py
|   |-- module.py
|   `-- things
|       |-- cross.png
|       |-- fplogo.png
|       `-- tick.png
|-- runner
|-- MANIFEST.in
|-- README
`-- setup.py

要制作安装压缩包,您只需运行:

python setup.py sdist

要安装软件包,请使用pipeasy_install

pip install my_package-1.2.3.tar.bz2

easy_install my_package-1.2.3.tar.bz2

也可以上传到PyPI,先注册一下:

python setup.py register

然后上传源压缩包

python setup.py sdist upload

你也可以上传二进制鸡蛋(虽然不是必须的):

python setup.py bdist_egg upload

然后人们可以像这样安装它:

pip install my_package==1.2.3

或者,

easy_install my_package==1.2.3

【讨论】:

  • @mit 嗯嗯;如果你想保持最低限度,__import__('setuptools').setup(name='myapp') 就足够了 :)
  • 上传 bdist_eggs 不仅没有必要,而且可能是有害的。仅当您为需要安装 C 编译器的 Windows 构建包时才这样做。
  • @Marius Gedminas 你能引用你关于鸡蛋危害的来源吗?我很少使用它们,但它们对于没有安装开发库的人很有用(如果包有 C 扩展)。对于 windows,bdist_wininst 可能会更好,因为它也像鸡蛋一样工作(easy_installpip 可以解压它们),但也允许用户通过 GUI 界面安装。
  • 我手头没有任何网址,抱歉。这是许多邮件列表对话的结果,主要是关于人们在 Linux 平台上遇到不兼容的二进制 .egg 包时遇到的问题。 Linux 没有明确定义的 Python ABI——为一个发行版的一个版本构建的 .so 文件很可能无法在不同的发行版上运行,甚至在同一发行版的不同版本上运行。因此,我的经验法则是:只在 Windows 上构建 bdist_egg。
猜你喜欢
  • 2020-09-18
  • 2011-02-01
  • 1970-01-01
  • 1970-01-01
  • 2011-11-15
  • 1970-01-01
  • 1970-01-01
  • 2015-08-03
  • 2016-07-11
相关资源
最近更新 更多