温欣爸比

  • 主页
  • Alfred Workflow
  • 《Vim 练级手册》
  • 常用命令
  • 代码笔记
  • 合辑
  • 在线工具
所有文章 友链 关于我

温欣爸比

  • 主页
  • Alfred Workflow
  • 《Vim 练级手册》
  • 常用命令
  • 代码笔记
  • 合辑
  • 在线工具

Python 编写 pip 包并上传到 pypi

2018-07-13

用了这么长时间的 python,一直想写些开源的东西回馈社区,最近在封装微信的公众平台,借着机会研究了下怎样封装 pip 包,并上传到 pypi。



  • 创建项目
  • 安装到本地测试
  • 打包
  • 上传 pypi

创建项目

首先创建项目,目录结构如下

1
2
3
4
5
6
7
8
-- wwx
|
|-- wwx
| |
| |-- __init__.py
| |-- models.py
|
|-- setup.py

其中 wwx/wwx 是主代码目录,setup.py 是必备的打包文件

setup.py

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
#!/usr/bin/env python
# -*- coding:utf-8 -*-
# Author: wxnacy(wxnacy@gmail.com)
# Description:

from setuptools import setup, find_packages

setup(
name = 'wwx',
version = '0.0.1',
keywords='wx',
description = 'a library for wx Developer',
license = 'MIT License',
url = 'https://github.com/wxnacy/wwx',
author = 'wxnacy',
author_email = 'wxnacy@gmail.com',
packages = find_packages(),
include_package_data = True,
platforms = 'any',
install_requires = [
'requests>=2.19.1',
'pycrypto>=2.6.1',
'xmltodict>=0.11.0'
],
)

项目代码根据你的需求编写,你可以写一个这样的例子来测试

models.py

1
2
3
4
5
6
7
8
#!/usr/bin/env python
# -*- coding:utf-8 -*-
# Author: wxnacy(wxnacy@gmail.com)

class Message():
@classmethod
def test():
print('Hello World')

__init__.py

1
2
3
4
5
#!/usr/bin/env python
# -*- coding:utf-8 -*-
# Author: wxnacy(wxnacy@gmail.com)

from .models import Message

安装到本地测试

接下来在 setup.py 所在目录下执行安装命令,安装到本地

1
$ pip install .

在项目中你就可以使用测试了

1
2
3
4
5
6
7
#!/usr/bin/env python
# -*- coding:utf-8 -*-
# Author: wxnacy(wxnacy@gmail.com)

from wwx import Message

Message.test()

打包

测试完成后,再上传到 pypi 之前需要先打包

1
$ python setup.py <params>

params 有如下取值

1
2
3
4
5
6
sdist             create a source distribution (tarball, zip file, etc.)
bdist create a built (binary) distribution
bdist_dumb create a "dumb" built distribution
bdist_rpm create an RPM distribution
bdist_wininst create an executable installer for MS Windows
bdist_egg create an "egg" distribution

sdist 可以支持上传到 pypi

1
$ python setup.py sdist

然后根目录中会出现 dist 目录存放打包文件

上传 pypi

最后一步上传到 pypi,首先去官网搜索确认项目名没有被占用,并注册用户,然后使用 twine 进行上传

下载 twine

1
$ pip install twine

上传

1
$ twine upload dist/*

然后根据提示输入用户名密码即可。

设置全局账户信息

创建 ~/.pypirc 文件并添加如下信息

1
2
3
4
5
6
7
[distutils]
index-servers=pypi

[pypi]
repository = https://upload.pypi.org/legacy/
username = <username>
password = <password>

然后再次上传就不会提示输入用户密码了

最近更新
Alfred Workflow 命令行帮助工具
最近热读
Go 判断数组中是否包含某个 item
Vim 高级功能 vimgrep 全局搜索文件
办理北京工作居住证的一些细节
Go 语法错误:Non-declaration statement outside function body
Mac 电脑查看字体文件位置
扫码关注公众号,或搜索公众号“温欣爸比” 及时获取我的最新文章
赏

谢谢你请我喝咖啡

支付宝
微信
  • python
微信第三方平台授权问题:此公众号没有这些scope的权限
Flask 操作 Cookie
  1. 1. 创建项目
  2. 2. 安装到本地测试
  3. 3. 打包
  4. 4. 上传 pypi
© 2017 - 2022 温欣爸比 京ICP备15062634号 总访问量1359184次 访客数1117030人次 本文总阅读量1853次
Hexo Theme Yilia by Litten
  • 所有文章
  • 友链
  • 关于我

tag:

  • python
  • flask
  • javascript
  • docker
  • 工具
  • openresty
  • 微信
  • java
  • hexo
  • 杂谈
  • vim
  • git
  • mysql
  • http
  • linux
  • mac
  • tmux
  • ssh
  • 算法
  • 开发
  • node
  • 杂文
  • jinja2
  • maven
  • spring
  • 北京
  • 生活
  • springboot
  • react
  • shell
  • graphql
  • iterm
  • expect
  • nginx
  • sqlalchemy
  • html
  • electron
  • vagrant
  • elastic
  • 宝贝
  • ansible
  • css
  • jquery
  • go
  • markdown
  • awk
  • redis
  • leetcode
  • zsh
  • 漫威
  • ssr
  • android
  • ffmpeg
  • chrome
  • vmware
  • youtube
  • windows
  • jupyter
  • excel
  • jq
  • Mac
  • Homebrew
  • mongo
  • py2
  • HomeBrew
  • movie
  • nodejs

    缺失模块。
    1、请确保node版本大于6.2
    2、在博客根目录(注意不是yilia根目录)执行以下命令:
    npm i hexo-generator-json-content --save

    3、在根目录_config.yml里添加配置:

      jsonContent:
        meta: false
        pages: false
        posts:
          title: true
          date: true
          path: true
          text: false
          raw: false
          content: false
          slug: false
          updated: false
          comments: false
          link: false
          permalink: false
          excerpt: false
          categories: false
          tags: true
    

  • Guru99
每天看书
每天背单词
每天一篇
写写代码
听听周杰伦
爱爱老婆