translating

This commit is contained in:
geekpi 2021-11-15 08:39:45 +08:00
parent b54d314efd
commit 1c1d9d511d
2 changed files with 206 additions and 205 deletions

View File

@ -1,205 +0,0 @@
[#]: subject: "How to package your Python code"
[#]: via: "https://opensource.com/article/21/11/packaging-python-setuptools"
[#]: author: "Seth Kenlon https://opensource.com/users/seth"
[#]: collector: "lujun9972"
[#]: translator: "geekpi"
[#]: reviewer: " "
[#]: publisher: " "
[#]: url: " "
How to package your Python code
======
Use setuptools to deliver Python code to users.
![Python programming language logo with question marks][1]
You've spent weeks perfecting your code. You've tested it and sent it to some close developer friends for quality assurance. You've posted all the source code on [your personal Git server][2], and you've received helpful bug reports from a few brave early adopters. And now you're ready to make your Python code available to the world.
And that's when it hits you. You have no idea how to deliver the product.
Delivering code to its target is a big deal. It's a whole branch of software development, it's the "D" in CI/CD, and yet many people forget all about, at least until the end. I've written articles about [Autotools][3] and [Cmake][4], but some languages have their own methods to help you make your code readily available to users. For Python, a common way to deliver code to users is with `setuptools`.
### Install setuptools
The easiest way to install and update `setuptools` is with `pip`:
```
`$ sudo python -m pip install --upgrade setuptools`
```
### Example library
Create a simple Python library called `myhellolib` for some example code in need of packaging. This library accepts a string and then prints the string in capital letters.
It's two lines of code, but project structure is important, so first create the directory tree:
```
`$ mkdir -p myhellolib.git/myhellolib`
```
To confirm that this project is an importable library (a Python "module"), create the empty file `__init__.py` in the code directory, along with the file that contains the code:
```
$ touch myhellolib.git/myhellolib/__init__.py
$ touch myhellolib.git/myhellolib/myhellolib.py
```
In the `myhellolib.py` file, enter this simple Python code:
```
def greeter(s):
    print(s.upper())
```
That's the library written.
### Test it
Before packaging it up, test your library. Create a `myhellolib.git/test.py` file and enter this code:
```
import myhellolib.myhellolib as hello
hello.greeter("Hello Opensource.com.")
```
Run the script:
```
$ cd myhellolib.git
$ python ./test.py
HELLO OPENSOURCE.COM
```
It works, so now you can package it up.
### Setuptools
To package a project with `setuptools`, you must create a `.toml` file identifying `setuptools` as the build system. Place this text in a file called `myhellolib.toml` in your project directory:
```
[build-system]
requires = ["setuptools", "wheel"]
build-backend = "setuptools.build_meta"
```
Next, create a file called `setup.py`, containing metadata about your project:
```
from setuptools import setup
setup(
    name='myhellolib',
    version='0.0.1',
    packages=['myhellolib'],
    install_requires=[
        'requests',
        'importlib; python_version == "3.8"',
    ],
)
```
Believe it or not, that's all the setup `setuptools` requires. Your project is ready for packaging.
### Packaging Python
To create your Python package, you need a builder. A common tool is `build`, which you can install with `pip`:
```
`$ python -m pip install build --user`
```
Build your project:
```
`$ python -m build`
```
After a few moments, the build completes, and there's a new directory in your project folder called `dist`. This folder contains a `.tar.gz` and a `.whl` file.
Your very first Python package! Here's what each one contains:
```
$ tar --list --file dist/myhellolib-0.0.1.tar.gz
myhellolib-0.0.1/
myhellolib-0.0.1/PKG-INFO
myhellolib-0.0.1/myhellolib/
myhellolib-0.0.1/myhellolib/__init__.py
myhellolib-0.0.1/myhellolib/myhellolib.py
myhellolib-0.0.1/myhellolib.egg-info/
myhellolib-0.0.1/myhellolib.egg-info/PKG-INFO
myhellolib-0.0.1/myhellolib.egg-info/SOURCES.txt
myhellolib-0.0.1/myhellolib.egg-info/dependency_links.txt
myhellolib-0.0.1/myhellolib.egg-info/requires.txt
myhellolib-0.0.1/myhellolib.egg-info/top_level.txt
myhellolib-0.0.1/setup.cfg
myhellolib-0.0.1/setup.py
$ unzip -l dist/myhellolib-0.0.1-py3-none-any.whl 
Archive:  dist/myhellolib-0.0.1-py3-none-any.whl
Name
\----
myhellolib/__init__.py
myhellolib/myhellolib.py
myhellolib-0.0.1.dist-info/METADATA
myhellolib-0.0.1.dist-info/WHEEL
myhellolib-0.0.1.dist-info/top_level.txt
myhellolib-0.0.1.dist-info/RECORD
\-------
6 files
```
### Making it available
Now that you know how easy it is to package up your Python package, you can either automate the process using Git hooks, GitLab webhooks, Jenkins, or a similar automation tool. You can even upload your project to PyPi, the popular repository for Python modules. Once it's on PyPi, users can install it using `pip`, the same way you installed `setuptools` and `build` for this article!
It's not often the first thing you think about when sitting down to develop an application or library, but packaging code is an important aspect of programming. Python developers put a lot of thought into how programmers can make their work available to the world, and it doesn't get much easier than `setuptools`. Try it out, use it, and keep coding in Python!
Python is a popular language for many applications. Those that run as backend services, now in the...
--------------------------------------------------------------------------------
via: https://opensource.com/article/21/11/packaging-python-setuptools
作者:[Seth Kenlon][a]
选题:[lujun9972][b]
译者:[译者ID](https://github.com/译者ID)
校对:[校对者ID](https://github.com/校对者ID)
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
[a]: https://opensource.com/users/seth
[b]: https://github.com/lujun9972
[1]: https://opensource.com/sites/default/files/styles/image-full-size/public/lead-images/python_programming_question.png?itok=cOeJW-8r (Python programming language logo with question marks)
[2]: https://opensource.com/life/16/8/how-construct-your-own-git-server-part-6
[3]: https://opensource.com/article/19/7/introduction-gnu-autotools
[4]: https://opensource.com/article/21/5/cmake

View File

@ -0,0 +1,206 @@
[#]: subject: "How to package your Python code"
[#]: via: "https://opensource.com/article/21/11/packaging-python-setuptools"
[#]: author: "Seth Kenlon https://opensource.com/users/seth"
[#]: collector: "lujun9972"
[#]: translator: "geekpi"
[#]: reviewer: " "
[#]: publisher: " "
[#]: url: " "
如何打包你的 Python 代码
======
使用 setuptools 来向用户提供 Python 代码。
![Python programming language logo with question marks][1]
你花了几周的时间来完善你的代码。你已经对它进行了测试,并把它发送给一些亲密的开发者朋友以保证质量。你已经将所有的源代码发布在[你的个人 Git 服务器][2]上,并且已经收到了一些勇敢的早期使用者的有用的错误报告。现在你已经准备好将你的 Python 代码提供给全世界。
就在这时你遇到一个问题。你不知道如何交付产品。
将代码交付给它的目标是一件大事。这是软件开发的一个完整的分支,是 CI/CD 中的 “D”但很多人都忘记了至少到最后才知道。我写过关于 [Autotools][3] 和 [Cmake][4] 的文章,但有些语言有自己的方法来帮助你将你的代码随时提供给用户。对于 Python 来说,向用户提供代码的一个常见方法是使用 `setuptools`
### 安装 setuptools
安装和更新 `setuptools` 的最简单方法是使用 `pip`
```
`$ sudo python -m pip install --upgrade setuptools`
```
### 示例库
为一些需要打包的示例代码创建一个简单的 Python 库,名为 `myhellolib`。这个库接受一个字符串,然后用大写字母打印出这个字符串。
它只有两行代码,但项目结构很重要,所以首先创建目录树:
```
`$ mkdir -p myhellolib.git/myhellolib`
```
为了确认这个项目是一个可导入的库(一个 Python “模块”),在代码目录中创建一个空文件 `__init__.py`,同时创建一个包含代码的文件:
```
$ touch myhellolib.git/myhellolib/__init__.py
$ touch myhellolib.git/myhellolib/myhellolib.py
```
`myhellolib.py` 文件中,输入简单的 Python 代码:
```
def greeter(s):
print(s.upper())
```
这就是写好的库。
### 测试它
在打包之前,测试一下你的库。创建一个 `myhellolib.git/test.py` 文件并输入以下代码:
```
import myhellolib.myhellolib as hello
hello.greeter("Hello Opensource.com.")
```
运行该脚本:
```
$ cd myhellolib.git
$ python ./test.py
HELLO OPENSOURCE.COM
```
它可以工作,所以现在你可以把它打包了。
### Setuptools
要用 `setuptools` 打包一个项目,你必须创建一个 `.toml` 文件,将 `setuptools` 作为构建系统。将这段文字放在项目目录下的 `myhellolib.toml` 文件中。
```
[build-system]
requires = ["setuptools", "wheel"]
build-backend = "setuptools.build_meta"
```
接下来,创建一个名为 `setup.py` 的文件,包含项目的元数据:
```
from setuptools import setup
setup(
name='myhellolib',
version='0.0.1',
packages=['myhellolib'],
install_requires=[
'requests',
'importlib; python_version == "3.8"',
],
)
```
不管你信不信,这就是 `setuptools` 需要的所有设置。你的项目已经可以进行打包。
### 打包 Python
要创建你的 Python 包,你需要一个构建器。一个常见的工具是 `build`,你可以用 `pip` 安装它:
```
`$ python -m pip install build --user`
```
构建你的项目:
```
`$ python -m build`
```
过了一会儿,构建完成了,在你的项目文件夹中出现了一个新的目录,叫做 `dist`。这个文件夹包含一个 `.tar.gz` 和一个 `.whl` 文件。
这是你的第一个 Python 包! 下面是包的内容:
```
$ tar --list --file dist/myhellolib-0.0.1.tar.gz
myhellolib-0.0.1/
myhellolib-0.0.1/PKG-INFO
myhellolib-0.0.1/myhellolib/
myhellolib-0.0.1/myhellolib/__init__.py
myhellolib-0.0.1/myhellolib/myhellolib.py
myhellolib-0.0.1/myhellolib.egg-info/
myhellolib-0.0.1/myhellolib.egg-info/PKG-INFO
myhellolib-0.0.1/myhellolib.egg-info/SOURCES.txt
myhellolib-0.0.1/myhellolib.egg-info/dependency_links.txt
myhellolib-0.0.1/myhellolib.egg-info/requires.txt
myhellolib-0.0.1/myhellolib.egg-info/top_level.txt
myhellolib-0.0.1/setup.cfg
myhellolib-0.0.1/setup.py
$ unzip -l dist/myhellolib-0.0.1-py3-none-any.whl
Archive: dist/myhellolib-0.0.1-py3-none-any.whl
Name
\----
myhellolib/__init__.py
myhellolib/myhellolib.py
myhellolib-0.0.1.dist-info/METADATA
myhellolib-0.0.1.dist-info/WHEEL
myhellolib-0.0.1.dist-info/top_level.txt
myhellolib-0.0.1.dist-info/RECORD
\-------
6 files
```
### 让它可用
现在你知道了打包你的 Python 包是多么容易,你可以使用 Git 钩子、GitLab webhooks、Jenkins 或类似的自动化工具来自动完成这个过程。你甚至可以把你的项目上传到 PyPi这个流行的 Python 模块仓库。一旦它在 PyPi 上,用户就可以用 `pip` 来安装它,就像你在这篇文章中安装 `setuptools``build` 一样!
当你坐下来开发一个应用或库时打包并不是你首先想到的事情但它是编程的一个重要方面。Python 开发者在程序员如何向世界提供他们的工作方面花了很多心思,没有比 `setuptools` 更容易的了。试用它,使用它,并继续用 Python 编码!
--------------------------------------------------------------------------------
via: https://opensource.com/article/21/11/packaging-python-setuptools
作者:[Seth Kenlon][a]
选题:[lujun9972][b]
译者:[geekpi](https://github.com/geekpi)
校对:[校对者ID](https://github.com/校对者ID)
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
[a]: https://opensource.com/users/seth
[b]: https://github.com/lujun9972
[1]: https://opensource.com/sites/default/files/styles/image-full-size/public/lead-images/python_programming_question.png?itok=cOeJW-8r (Python programming language logo with question marks)
[2]: https://opensource.com/life/16/8/how-construct-your-own-git-server-part-6
[3]: https://opensource.com/article/19/7/introduction-gnu-autotools
[4]: https://opensource.com/article/21/5/cmake