之前一直在线上服务器裸敲Python,很久没有在自己的mac上写了。最近有任务要用Python来实现,借此好好整理关于Python环境设置和工程搭建遇到的问题。
示例工程地址: https://github.com/rainfd/python-example-project
ENVIROMMENT
安装 Python
brew install python
安装 Python2/3,虽然在今年官方就正式停止了对 Python2 的支持,但已经在线上运行的系统还是默认跑着 Python2. 像 Centos7.6 才会默认使用 Python3, 那在近几年内 Python2 还是避不开了.
IDE
不是用 Python 作为主力语言,那么买 Pycharm 就没什么必要了. 在其余的几个常用 IDE 中(VSCode/Sublime Text3/Atom), 我选了 VSCode.原因是我 Golang 也是在 VSCode 上开发的.配置 Python 相关的环境也不需要折腾什么.
安装 Python 插件
在 marketplace 搜索 Python 的官方插件直接安装
pipenv
brew install pipenv
相对比于 pyenv,个人认为 pipenv 安装和使用更简单,还有完整的文档.
新建虚拟环境
$ cd python-example-project
$ pipenv --three
$ pipenv shell
(python-example-project) $ pipenv install package
(python-example-project) $ pipenv --venv
/Users/rainfd/.local/share/virtualenvs/python-example-project-9IUo4aoR
VSCode 配置虚拟环境
按下 ⇧⌘P/F1
, 输入 select interpreter
选择上面 venv 列出的路径.
又或者在 workspace 的 setting 中添加:
{
"python.pythonPath": "/Users/rainfd/.local/share/virtualenvs/python-example-project-9IUo4aoR/bin/python"
}
Shebang
#!/usr/bin/env python
# -*- encoding: utf-8 -*-
通常 Python 文件开头会加入 Shebang 或者其他作者/注释说明, 这里就要使用 VSCode 自带的 Snippet.菜单栏选择 Preferences>Use Snippets, 输入 python.json, 输入
{
"HEADER": {
"prefix": "header",
"body": ["#!/usr/bin/env python", "# -*- encoding: utf-8 -*-"]
}
}
PROJECT
Unit Test
Python 用于单元测试的框架有很多,但 Python 官方库就自带了一个不错的 unittest,那就没必要引入其他依赖了.
VSCode 配置 unittest
{
"python.testing.unittestArgs": ["-v", "-s", ".", "-p", "*_test.py"],
"python.testing.pytestEnabled": false,
"python.testing.nosetestsEnabled": false,
"python.testing.unittestEnabled": true
}
Mock
既然使用了 unittest, 那就少不了 unittest.mock 相对于其他语言的 mock 支持, 我是觉得 Python 的 mock 使用是最简单的.
要注意的是 unitest.mock 是 Python 3.3 加入到官方库的,假设使用 Python2,就需要额外安装 pipenv install mock
Log
全局日志可以参考这个https://gist.github.com/kingspp/9451566a5555fb022215ca2b7b802f19
通过 yaml 配置各个模块的日志格式和等级
在模块中只需要引入 logger 就可以正常输出日志
logger = logging.getLogger(__name__)
logger.info("msg")