python virtualenv and hug

2023-11-25 00:51
文章标签 python virtualenv hug

本文主要是介绍python virtualenv and hug,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

virtualenv

在开发Python应用程序的时候,系统安装的Python3只有一个版本:3.4。所有第三方的包都会被pip安装到Python3的site-packages目录下。

如果我们要同时开发多个应用程序,那这些应用程序都会共用一个Python,就是安装在系统的Python 3。如果应用A需要jinja 2.7,而应用B需要jinja 2.6怎么办?

这种情况下,每个应用可能需要各自拥有一套“独立”的Python运行环境。virtualenv就是用来为一个应用创建一套“隔离”的Python运行环境。

首先,我们用pip安装virtualenv:

$ pip3 install virtualenv

然后,假定我们要开发一个新的项目,需要一套独立的Python运行环境,可以这么做:

第一步,创建目录:

Mac:~ michael$ mkdir myproject
Mac:~ michael$ cd myproject/
Mac:myproject michael$

第二步,创建一个独立的Python运行环境,命名为venv

Mac:myproject michael$ virtualenv --no-site-packages venv
Using base prefix '/usr/local/.../Python.framework/Versions/3.4'
New python executable in venv/bin/python3.4
Also creating executable in venv/bin/python
Installing setuptools, pip, wheel...done.

命令virtualenv就可以创建一个独立的Python运行环境,我们还加上了参数--no-site-packages,这样,已经安装到系统Python环境中的所有第三方包都不会复制过来,这样,我们就得到了一个不带任何第三方包的“干净”的Python运行环境。

新建的Python环境被放到当前目录下的venv目录。有了venv这个Python环境,可以用source进入该环境:

Mac:myproject michael$ source venv/bin/activate
(venv)Mac:myproject michael$

注意到命令提示符变了,有个(venv)前缀,表示当前环境是一个名为venv的Python环境。

下面正常安装各种第三方包,并运行python命令:

(venv)Mac:myproject michael$ pip install jinja2
...
Successfully installed jinja2-2.7.3 markupsafe-0.23
(venv)Mac:myproject michael$ python myapp.py
...

venv环境下,用pip安装的包都被安装到venv这个环境下,系统Python环境不受任何影响。也就是说,venv环境是专门针对myproject这个应用创建的。

退出当前的venv环境,使用deactivate命令:

(venv)Mac:myproject michael$ deactivate 
Mac:myproject michael$

此时就回到了正常的环境,现在pippython均是在系统Python环境下执行。

完全可以针对每个应用创建独立的Python运行环境,这样就可以对每个应用的Python环境进行隔离。

virtualenv是如何创建“独立”的Python运行环境的呢?原理很简单,就是把系统Python复制一份到virtualenv的环境,用命令source venv/bin/activate进入一个virtualenv环境时,virtualenv会修改相关环境变量,让命令pythonpip均指向当前的virtualenv环境。

小结

virtualenv为应用提供了隔离的Python运行环境,解决了不同应用间多版本的冲突问题。


RESTful API 框架 HUG 指南

如果你在用 Python3,如果你需要搭建一个 API 服务,如果时间很紧,那么 HUG 可能就是你的最佳选择!本文将用轻松易懂的实例教程来带大家走入 HUG 的世界。


更新历史

  • 2017.03.09: 完成初稿

准备工作

HUG 是基于 Python3 的,所以我们来安装一下。一般来说我们会使用 virtualenv 来隔离不同的环境,不然不同的包容易『打架』。比较简单,跟着敲命令即可。

      
# 安装 Python3,其中 pip3 会随着 Python3 一并安装
# 编译时间会比较长,请耐心等待
brew install python3
# 安装 VirtualEnv 方便隔离开发
pip3 install virtualenv
# 新建一个 ~/hug 文件夹来保存
virtualenv -p python3 ~/hug
# 激活环境
source ~/hug/bin/activate
# 离开环境
deactivate

配置完成之后,我们就可以安装 hug 啦,直接 pip3 install hug --upgrade 即可。恭喜,一切完事儿!(如果你手滑,可以再 pip3 install bottle 一下,之后有用)

Hello World

按照通常的 Hello World 惯例,我们就来写一个 API,给访问这个 API 的用户问好。就是如下 7 行(文件名为 hello.py):

      
import time
import hug
@hug.get('/hello')
def hello(name):
"""Say Hello to the User"""
ticks = time.time()
return "Hello {name}! Now is {ticks}".format(**locals())

然后我们在命令行里输入 hug -f hello.py,就可以看到如下萌萌的启动界面:

然后我们来访问一下 127.0.0.1:8000,发现返回的结果是这个:

      
{
"404": "The API call you tried to make was not defined. Here's a definition of the API to help you get going :)",
"documentation": {
"handlers": {
"/hello": {
"GET": {
"usage": "Say Hello to the User",
"outputs": {
"format": "JSON (Javascript Serialized Object Notation)",
"content_type": "application/json"
},
"inputs": {
"name": {
"type": "Basic text / string value"
}
}
}
}
}
}
}

这个告诉我们,嘿这个 API 我们没有定义噢,但是我们很贴心的给你列出来已经定义的 API,剩下的你自己看咯!

好,我们现在知道了,要访问的是 127.0.0.1:8000/hello,于是我们打开浏览器再试一次,发现结果是这个:

      
{
"errors":
{
"name": "Required parameter 'name' not supplied"
}
}

噢,这个错误提醒我们,一定要给出 name 这个参数,好,那我们访问 127.0.0.1:8000/hello?name=wdxtub,结果终于对了,像这样(给出了名字,也给出了当前的时间戳):

      
"Hello wdxtub! Now is 1489061160.552566"

但是这个方法还有一点不好,就是我们改动了代码,并不会自动重新载入,每次都要手动重启很麻烦,那怎么办呢?下一节我们就来搞这个问题。

自动重启及 API 测试

还记得我们之前手滑安装的 bottle 吗?接下来就有用啦,我们把代码改成如下(注意新增的 import 和下面的 if 部分):

      
import hug
import time
from bottle import run
@hug.get('/hello')
def hello(name):
"""Say Hello to the User"""
ticks = time.time()
return "Hello {name}! Now is {ticks}".format(**locals())
if __name__ == "__main__":
app = __hug__.http.server()
run(app=app, reloader=True, port=8000)

然后在命令行中输入 python hello.py,就可以看到我们的 API 服务器启动起来了,如果这个时候我们对 hello.py 做些修改,bottle 会自动帮我们重启,非常方便!比如我们可以加入下面几行:

      
@hug.get('/', output=hug.output_format.json)
def root():
return {'msg': "欢迎来到 HUG 指南"}

稍等一下,就可以访问 127.0.0.1:8000 了。当然,使用浏览器测试 API 其实是不太方便的,这里推荐一下 Postman 这个 Chrome 应用,可以很方便地进行各类测试。比如像这样:

重新认识 HUG

官方的标题起的很威武霸气 - 拥抱未来的 API(Embrace the APIs of the future)。借用其简介:

Drastically simplify API development over multiple interfaces. With hug, design and develop your API once, then expose it however your clients need to consume it. Be it locally, over HTTP, or through the command line - hug is the fastest and most modern way to create APIs on Python3.

从前面的例子中我们其实也可以简单领略到 HUG 的魅力,这里简单总结一下:

  • 性能高。在如此高的抽象层仍旧不损失太多性能,值得称赞(接近最快的 falcon
  • 自带版本管理。简单制定所属的 API 版本,就可以用 v1v2 这样的方式来切换,方便
  • 自动化文档。只要简单地在代码中写注释及标注好类型,文档就自动生成了,省事儿
  • 标记即验证。利用 Python 3 的 type annotation 能力,可以对每个参数进行验证和转换
  • 写一次到处用。只能用作 API 吗?错!还可以用在命令行和其他 python 代码中,因为业务逻辑很干净

好了!现在你已经准备好了!可能教程不是特别『丰富』,但是相信你可以的,毕竟参考链接里可是有完整的教程呢!

参考链接

  • 包含教程及文档 - hug’s website
  • Github - timothycrosley/hug
  • 有用的代码样例
  • 必读 - 学习 HUG


转载自:

https://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000/001432712108300322c61f256c74803b43bfd65c6f8d0d0000

http://wdxtub.com/2017/03/09/hug-guide/

这篇关于python virtualenv and hug的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/422857

相关文章

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

Python正则表达式匹配和替换的操作指南

《Python正则表达式匹配和替换的操作指南》正则表达式是处理文本的强大工具,Python通过re模块提供了完整的正则表达式功能,本文将通过代码示例详细介绍Python中的正则匹配和替换操作,需要的朋... 目录基础语法导入re模块基本元字符常用匹配方法1. re.match() - 从字符串开头匹配2.

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

Python一次性将指定版本所有包上传PyPI镜像解决方案

《Python一次性将指定版本所有包上传PyPI镜像解决方案》本文主要介绍了一个安全、完整、可离线部署的解决方案,用于一次性准备指定Python版本的所有包,然后导出到内网环境,感兴趣的小伙伴可以跟随... 目录为什么需要这个方案完整解决方案1. 项目目录结构2. 创建智能下载脚本3. 创建包清单生成脚本4

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e