Python web 开发框架 Pyramid

在Python web 开发框架里有多种选择,有DjangoTornado、Flask、web2py、Pylons、Pyramid等等,之前写过Django、Tornado,今天我们主要学习Pyramid,还是从官方文档学起。

官方文档 = 新华字典

1.Pyramid

Pyramid 是 Pylons 项目下面一系列已经发行的软件中的一员。Pylons 官网描述了 Pyramid 和 Pylons Project 的关系。

Pyramid以其高效率和快节奏的开发能力而出名。官方文档是这样描述的:Pyramid is a small, fast, down-to-earth Python web framework. It is developed as part of the Pylons Project. It is licensed under a BSD-like license. 此开源Web框架有一个独立于平台的MVC结构,提供了开发的最简途径。此外,它还是高效开发重用代码的首选平台之一。

Pyramid 和其他 web 框架(由Pyramid英文文档翻译)

第一个 Pyramid 版本的前生(叫做 repoze.bfg )创建于 2008 年。2010 年末,我们把 repoze.bfg 改名为 Pyramid 并于同年11月份合并到 Pylons 项目中。

Pyramid 的灵感来源于 Zope、Pylons 1.0 和 Django ,最终,Pyramid 向它们各自借鉴一些概念和特性并组成一个独特的框架。

Pyramid 的许多特性都要追溯到 Zope 。像 Zope 应用程序一样,Pyramid 应用程序是易于扩展的:如果你遵守一定的规则,那么你的应用程序将会被重用、改进、重构,甚至被第三方开发者扩展而不用 fork 原始程序。 Traversal 和 declarative security 等概念都是在 Zope 中首先被提出来的。

Pyramid 的 URL dispatch 概念受 Pylons 1.0 版本的 Routes 系统启发的,Pyramid 像 Pylons 1.0 版本一样采用自由政策。它没有指定你应该使用哪个数据库,它的内置模板只是为了方便。实际上,它仅仅提供一种将 URL 映射到 view 代码上的机制,以及调用那些 views 的规则。你可以免费使用第三方组件来满足你项目的需求。

Pyramid 经常使用的 view 这一概念来自 Django 。Pyramid 的文档风格比起 Zope 更像 Django 。

类似 Pylons 1.0 版本,却不像 Zope ,一个 Pyramid 应用程序开发者可以使用一个完整的语句命令去执行一个框架常用的配置任务比如增加一个 view 或者一个 route 。在 Zope 里面 ZCML 也有类似功能。Pyramid 支持随时可用的命令语句配置和基于修饰符的配置;ZCML 通过一个扩展包 pyramd_zcml 使用。

既不像 Zope ,也不像 “full-stack” 这样的框架比如 Django ,Pyramid 对于你使用哪一种持续化的机制构建应用程序不做任何假设。Zope 应用程序依赖于 ZODB;Pyramid 也允许你创建 ZODB 程序但却不依赖 ZODB 本身。同样,Django 倾向于假定你想要把你的应用程序数据存储在一个关系型数据库中。Pyramid 从不做这些假设,它允许你使用关系型数据库但是不鼓励也不阻止的决定。

其他的 Python web framework 都宣称他们自己是一个类成员 web framework 叫做model-view-controller 框架,Pyramid 也属于这一类。

框架 VS 库 (由Pyramid英文文档翻译)

一个 框架 和一个 库 最大的区别在于:库里面的代码被你写的代码 调用 ,而框架则是 调用 你写的代码。使用一系列的库来创建应用程序通常在刚开始的时候要比使用框架简单,因为你可以有选择性地放弃一些控制权给不是你写的库代码。但是当你使用一个框架的时候,你必须放弃绝大部分的控制权交给那些不是你写的代码:整个框架。你不是必须使用一个框架来创建一个 WEB 应用程序在使用 Python 的情况下。一大批丰富的库都被已经被开发出来。然而在实际应用中,使用框架去创建应用要比使用一系列的库更加实用,如果这个框架提供的一些列功能都符合你的项目要求。

2.Pyramid的安装

官网讲的还是蛮清楚的,照着来就行。

  • 安装setuptools
    下载ez_setup.py(进入该页面后网页另存为ez_setup.py即可,记住存在D;\python目录下)。cmd进入D:\python目录,执行
python ez_setup.py 
  • 安装virtualenv
    用python目录下的Script/easy_install程序安装virtualenv:
easy_install virtualenv
  • 用virtualenv创建工作区
virtualenv --no-site-packages env
  • 安装pyramid
    执行完上面的步骤后应该多了一个env文件,cd env文件夹,然后执行
easy_install pyramid

3.Pyramid使用

1.创建第一个pyramid应用程序

from wsgiref.simple_server import make_server
from pyramid.config import Configurator
from pyramid.response import Response


def hello_world(request):
    return Response('Hello %(name)s!'%request.matchdict)

if __name__ == '__main__':
    #创建了一个Configuration类的实例config
    config = Configurator()
    #注册了一个以/hello/开头的URL路由,路由的名字就叫'hello'
    config.add_route('hello','/hello/{name}')
    #注册了一个view callable函数  URL Path(比如/hello/world)->route(比如'hello')->view callable(比如hello_world函数)
    config.add_view(hello_world,route_name='hello')
    #pyramid.config.Configurator.make_wsgi_app()方法来创建WSGI应用程序
    app = config.make_wsgi_app()
    #启动了一个WSGI服务
    server = make_server('0.0.0.0',8080,app)
    #serve_forever()方法创建了一个循环来接受外界的request请求
    server.serve_forever()

打开你的浏览器,输运行运行入http://localhost:8080/hello/world,将会显示“Hello world!”。
现在我们对这个示例程序有了一个基本的认识,接下来一步一步分析它是如何工作的。

  • Imports 包
    第2行引入了pyramid.config模块的Configurator类,第10行创建了它的一个实例,然后通过这个实例来配置我们的应用。
    跟其他Python web框架一样,Pyramid 用 WSGI 协议来将一个应用程序和web服务器联系到一起。而第一行用到的wsgiref模块就是WSGI服务的一种封装,现在wsgiref已经被引入Python 标准库了。
    第三行引入了pyramid.response.Response,用来返回response信息。

  • View Callable 声明
    第六行定义了一个hello_world函数,传入request参数,返回pyramid.response.Response类的一个实例。通过调用request对象的matchdict方法来输入匹配到的name路径。由于我们访问的是http://localhost:8080/hello/world,所以匹配到的是world并以“hello world”的字符串返回,如果你访问的是http://localhost:8080/hello/pyramid,那么返回的将是“hello pyramid!”。
    这个函数被称为 view callable(你可以叫它视图调用,但我还是觉得用英文的比较好)。 一个视图调用 接受一个参数:request 。 它将返回一个response 对象。 一个view callable不一定是一个函数,也可以是一个类或一个实例, 但是这里为了简单起见,我们用了函数。
    一个view callable总是伴随着调用 request对象。 一个request对象就代表着一个通过被激活的WSGI服务器传送到pyramid的HTTP请求。
    一个view callable还需要返回一个response对象。因为一个response对象拥有所有来制定一个实际的HTTP 响应所必要的信息。这个对象通过 wsgi 服务器,也就是Pyramid,转化为文本信息发送回请求的浏览器。为了返回一个response,每个view callable创建的一个response实例。在 hello_world函数中, 一个字符串作为response的body来返回。

  • Application Configuration 应用程序配置
    第10-15行是应用程序的配置信息。
    第10行创建了一个Configuration类的实例config,通过这个实例来对我们的Pyramid应用进行配置,包括路由,ip,端口等信息。调用config的各种方法设置应用程序注册表(application registry),对我们的应用程序进行注册。什么是application registry?下面是官方解释:


    第11行调用pyramid.config.Configurator.add_route()方法,注册了一个以/hello/开头的URL路由,路由的名字就叫'hello'。
    第12行config.add_v运行iew(hello_world, route_name='hello'),注册了一个view callable函数(也就是hello_world函数),当名为'hello'的路由被匹配时应该调用这个函数。 这三者的对应关系也就是URL Path(比如/hello/world)->route(比如'hello')->view callable(比如hello_world函数)。这样,一个前台页面就和一个后台处理方法对应起来了。
    WSGI Application Creation 创建WSGI应用程序
    当所有的配置工作完成后,python脚本通过pyramid.config.Configurator.make_wsgi_app()方法来创建WSGI应用程序。这个方法返回一个WSGI应用程序对象并传递给app引用,让WSGI服务器来使用。WSGI是一个让服务器能和python应用程序交流的协议。这里不打算深入探讨WSGI,如果你有兴趣,可以去官网wsgi.org了解更多。
    WSGI Application Serving
    最后两行,我们启动了一个WSGI服务。make_server('0.0.0.0',8080,app)方法绑定了ip和端口,最后一个参数传递我们的app对象(一个router),也就是我们想服务的那个应用程序。serve_forever()方法创建了一个循环来接受外界的request请求。

运行测试

4.Pyramid部分语法

  • locals()用法:locals()可以直接将函数中所有的变量全部传给模板。当然这可能会传递一些多余的参数,有点浪费内存的嫌疑。

  • render()方法是render_to_response的一个崭新的快捷方式,前者会自动使用RequestContext。而后者必须coding出来,这是最明显的区别,当然前者更简洁。

return render_to_response('blog_add.html',{'blog': blog, 
'form': form, 'id': id, 'tag': tag},
context_instance=RequestContext(request))

return render(request, 'blog_add.html', 
{'blog': blog, 'form': form, 'id': id, 'tag': tag})
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,233评论 6 495
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,357评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,831评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,313评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,417评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,470评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,482评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,265评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,708评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,997评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,176评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,827评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,503评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,150评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,391评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,034评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,063评论 2 352

推荐阅读更多精彩内容