WebProgramming - PythonInfo Wiki
Python WEB应用框架纵览 |
收集并描述各种基于Python 的WEB 开发平台,指引我们的敏捷开发 |
Contents
Python + Web ~ SWiK 的收集和整理,,,
- SEE
PyWebFrameVs ~ 框架对比
PyTemplates ~ 模板系统
1. 超级框架
1.1. Twisted
Twisted ~ 框架的框架!
2. 主流框架
2.1. CherryPy
CherryPyQuickIn --- 快速进入 美味的樱桃
2.2. Django
DjanGo -- 悄悄开发成功的高级 Web Framework, 比以前的,更加注重整体设计
DjangoStepByStep -- limodou 开启的体验式学习教程!
Django 与 Flash 的结合!-- 带给你更为强大的Web体验 Azureon
Django中文文档:http://www.woodpecker.org.cn/obp/django/django-faq/TableOfContents.html
2.3. TurboGears
TurboGears -- 超强涡轮!
TurboGearStepByStep -- 等待开启的体验式学习教程!
2.4. Karrigell
KarriGell -- 永远安心工作的“推车”
KarrigellQuickIn --- 快速体验
KarrigellTutorial -- Karrigell 教程
2.5. web2py
2.6. web.py
webpy 国内相关项目推介:http://www.simple-is-better.com/news/webpy
2.7. Pylons
2.8. Quixote.堂吉诃德
QuixoteQuickIn --- 快速进入 无畏的骑士! 豆瓣 的主要动力系统!
2.9. Paste
2.10. Myghty
MyghtyOrg -- 模板核心的框架
2.11. Zope系列
- 基础宣传
ZopeSpread -- Zope 平台推广文章
- Zope3 时代
ZopeX3--全新开发的应用平台!
- 但是!和ZOPE2的变化实在是太大了。难怪ZOPE3从2001年开始开发,一直到现在还有release呢,整个架构变了,连使用习惯都变了,对于想转到Zope3开发的人员来说是一个比较麻烦的问题。
Zope3Book -- 紧跟最新成果的翻译项目!honeyday 发起!
三十分钟学会Zope3 -- 野火星兔
ZCA
ZopeComponentArchitecture ~ Zope 组件体系跨越思想的应用建筑基础
- Zope2 平台
Zope2Book -- 杜文山版!
MyZopeBook -- 我们翻译的Zope 相关文档
LearningZodb - ZODB学习全记录 -- hoxide 发起
- CMF 框架
CMF -- 内容管理框架
Plone -- 集成信息平台
PloneSpread -- Plone 推广文章
061111 SPUG 聚会资料:看图识Plone
3. 国人框架
3.1. Uliweb
- Uliweb -- 由limodou发起,多人参加的开源web框架。
- 集众家之长的框架!
3.2. 悟空智轮
WukooPy -- lihui 混合 Karrigell 和 Quixote 创造的 一个应用轮子
- 哈哈哈!别直接龙了,叫 蟒龙是也乎?
3.3. pynixweb
- 聚合所有的最佳实践
- 力求简单有效
4. CMS框架
4.1. itools
4.2. payago
4.3. pylucid
[http://www.pylucid.org/ pylucid
4.4. skeletonz
4.5. teeny_tiny_cms
5. 边缘框架
5.1. Dabo
DaBo -- 又一个默默发展的快速开发平台!
5.2. Storm
http://storm.canonical.com/Tutorial
- Ubuntu 社区主要支持公司 canonical 释放的,值得期待
5.3. Snakelets
SnakeletsQuickIn --- 快速进入 丰富的蛇件
5.4. ikaaro
IkaaRo -- 从工具包入手的CMS 构建包
5.5. atocha
atocha -- 一个围绕表单的web framework
- 感觉还不错,可以考虑嵌在其它的web应用中用来生成表单 -- Limodou
5.6. robaccia
RobaCcia - http://code.google.com/p/robaccia/ Joe Gregrio 的兼容WSGI的"垃圾"框架 (robaccia是意大利文"垃圾")
5.7. colubrid
ColuBrid - http://wsgiarea.pocoo.org/colubrid/ 同样WSGI兼容的 "非框架" 框架
5.8. aquarium
5.9. RhubarbTart
Contents
6. Pythonic Web 应用平台对比
更多的Py实现 CMS--内容管理平台 |
|
6.1. 再次综合对比
6.1.1. limodou 曰
limodou <[email protected]> hide details 4:52 pm (8 hours ago) reply-to [email protected] to [email protected] date Jul 8, 2007 4:52 PM subject Re: [python-chinese] 现在python的web框架这么多,有没有人能分析分析各自的优点缺点?
从级别上来说:
- 轻量级:web.py karrigell cherrypy
- 中量级:django, tg, pylons
- 重量级:zope/plone
- 从个人的体会:轻量级适用范围太小,象web.py, karrigell还算全面,而cherrypy就应该只算一个web
server级的了,许多东西都没有,大量的要自已去做.从这三者中如果要选择,我会选择karrigell.karrigell更接近php,功能比较多,模板丰富.
- 不过既然是轻量级,自然会过渡到更高量级的框架上,这是随着你对web开发的要求越来越高,比如ORM, 模板,更好的组织方式,自动化的功能,可参考的项目等等因素.
- 从中量级已经有过不少人对tg和django进行比较,在ibm开发者网站上还有过,网上也不少,不过可能大多是比较ROR与django.从设计哲学上来看,tg与pylons很接近,它们都是若干个项目的集成,而且目前越来越趋同,比如都使用mako模板,sqlalchemy这个ORM.而且有一个sprint是在pylons上跑tg,不过没有仔细研究过.大量地使用了wsgi.构建基础是在setuptools之上,甚至还使用了setuptools提供的插件机制可以从网上自动安装东西.
- 而django则可以认为是一站式的框架,不象tg/pylons需要安装大量的第三方的模块,安装django很简单,以前有阵子django的安装框架也是使用setuptools,但是因为使用了setuptools,如果你的python不是2.5以上版本,因此setuptools不是内置的,所以需要单独安装,后来django团队认为这个并不能带来什么好处,因此它内置不信赖于setuptools的某机强大的机制,再加上对于没有安装setuptools的人并不方便,所以就改为原始的setup方式了.所以从这里也可以看出django的设计是集成化的方式,与tg/pylons差别之巨大.因此有人想过何时tg与pylons会合并也正是因为它们设计思路的接近,而django与其它两者之间基本上是不可能的.关于django的功能不想过多的介绍了,应该有不少,最大的特点要算是:admin功能自动生成,正则式方式的url设计,简洁而拘谨的template,自成体系的ORM,出色的i18n的支持,目前又已经将unicode分支合并到主干上来了.
从三者出现的时间来说:django>tg>pylons.
- 我为什么选择django,主要是django的设计哲学与我个人的习惯接近,我认为django安装使用方式,不用自动从网上下载若干个模块,对安装非常方便.而且因为django出来的早,所以在没有发布前就从python邮件列表中得到消息就已经开始关注了,所以对它的态度可能有些先入为主.再加上django最具影响力的就是Guido
van Rossum这位python的创始人在多个场个宣传他喜欢django,就是在最近的Google developer day上,在北京见到这位"明星"他还在说:"I like django".因为我想他的一个观点就是:"Simple is the best.". 当然象大朗所说学习成本高要看怎么说了.如果你的要求高,django有许多高要求的东西,学起来自然很高.如果你的要求低,功能自然差了许多,而且可以使用admin,所以学习成本不高.而且每种框架都有自身的难度,深入下去自然要求比较高.这种高要求也许不全是学习成本,比如有些功能可能框架就没有, 这种难度就不再是学习的难度而是需要由你设计或寻找一个可用实例的难度了.
- web框架我要说:因为简单的会不够用,所以迟早会选择一个功能强大全面的框架.框架需要有活力,有发展.要看自身的要求与关注点,从多个框架中选择一个合适自已的.至少从功能来说django/tg/pylons是差不多的,而如果tg/pylons如果合并的话,就有两个功能相当,适合两种不同的使用习惯的人使用了.
- zope/plone可能需要专业从事web开发的人长期的投入,它就象一片大海,让人很难摸清楚.zope我只学过zope2,而且还是只会使用dtml,zclass, python script来开发,象product,tal都没有使用过.而zope3更不要说了.而plone是基于zope之上的一个cms的产品,功能更强大,内容更多.学习zope/plone更多的是在使用产品,大量的时间可能是花在学习zope和plone的组件的学习上,而不是python本身.而django/tg/pylons则许多还是依赖于python的语法功能,如decorator等,还是可以明显得看出python的东西来,学习的感受不太一样.再如zope3中采用了xml来描述配置,引入了interface,这些在其它的python开发中应用并不广泛,不能说它不好,只是说可能与一般的python程序员所追求的"Simple is the best"可能不太一致.习惯了简单东西的python程序员可能很难再去投入到一个看上去复杂的体系中了.我可能就是这样的.
6.1.2. 沈崴 曰
沈崴 <[email protected]> hide details 12:36 am (40 minutes ago) reply-to [email protected] to [email protected], [email protected] date Jul 9, 2007 12:36 AM subject [CPyUG:28791] Re: [python-chinese] 现在python的web框架这么多,有没有人能分析分析各自的优点缺点? mailed-by googlegroups.com
赵老师, 您好! 我曾走马观花地尝试过上述某些框架, 略有些感想, 希望能对您有所帮助
- 0. Limodou 关于这些工具级别的阐述说得很好!
- 1. Ruby on Rails, 当项目进行到一半的时候, 所有人都意识到这其实是一个错误。因此, 我们放弃了 ROR。对 Python
程序员而言, 除非 ROR 带来的商业利益超过成本上的支出, 否则很难适应 ROR 的效率。打个比方, 在 Plone 中尽管你可以使用 ArchGenXML 通过 UML 图来建立 Plone 应用, 但是真正开始使用后, 我们会发现手写 Archetypes 代码其实要比画 UML 图要来得方便和快捷。
- 2. Zope/Plone 是我现在完成所有应用的首选。Plone 已经自带用户、权限等系统,
你完全没必要自己作任何事情。Archetypes 拥有难以置信的建模能力, 搜索引擎和增删改页面全自动生成。Plone 自带的工作流引擎允许你靠鼠标完成工作流设计。使用得当, Plone 能带来几十倍的开发效率提升。Plone 也有非常严重的问题。首先,几乎所有人都认为 Plone 很慢, 事实上, Plone Skin 带来了太多 IO, 明白这一点, 我们能把 Plone 加速到和 CherryPy2 不相上下的程度。其次, 很多人对 Plone 定制苦不堪言, 但是如果不过于依赖 Plone Skin, 那么这也不是一个问题。最后, Plone 的栈很深, 不是所有人都会有足够耐心花几年时间来熟练地使用她, 这才是真正的问题 (在下认为这是完全值得的)。
- 3. 当应用不足以用到 Plone (比如我突然要为字符终端程序编写一个系统后台守护进程), 特别地, 当 Plone
过于完善的系统反而完全束缚了我们, 既然 Django 看上去是目前最好的框架, 这时候我选择 Django。这或许从一个侧面反映了一个在国内鲜为人知的情况, 那就是无论是国内还是国外, 使用 Plone 的应用要远超过 Django, 但是 Plone 程序员不会告诉你哪些站点是用 Plone 开发的, 因为这太偷懒了。常常, 这时任务会简单到直接使用 SimpleHTTPServer.py 就可以解决, 因此即使是一个临时方案, Django 还是很少被我用到。
4. TurboGears 系的程序员或许会感慨没有像 Django 那么好用的 URL 映射系统, 这是个意想不到的大问题,
因为黑客或许会选择像 TG 那样通过重用构建起来的东西, 但是他们更喜欢正则。
作为 TurboGears 系的一员,小弟斗胆猜测大家的潜台词可能都是: 我们爱 CherryPy 这样的好东西, 这带来了另一个意想不到的大问题: Apache Proxy已经是一个 Tree Mount 和正则发布系统, 无论对 CherryPy 还是 Django 这都绝对不是一个好消息。
接下来,CherryPy 也没有传说中那么快, CherryPy2 已经是有定论了, 而我测试的 CherryPy3 通常也没有能达到 500
个请求每秒的速度。至于 CherryPy3 的 TurboGears 是否能用, 在下也还没有尝试过。
如果在同级应用中 TurboGears系能和 Django 分庭抗礼, 我个人觉得只有一个可能, 那就是 TurboGears (或者直接说 CherryPy)要更简单一些。我个人最先接触到 CherryPy, 这样 TurboGears 系在实际中就用得更多一些, 但是这并不说明我喜欢 TG 要超过 Django。
5. web.py 是对 Django、TurboGears 这些框架的反动, 既然不能像 Plone 这样大而全, 何苦搞得那么复杂?
在下认为, web.py 的作者同样对 SimpleHTTPServer.py 这类的标准库同样非常不满。不过有点尴尬, 我对各种层次的应用都已经有合适的方案了, 而目前所有流行框架不能完成的事情 web.py 同样也搞不定。在下意识到或许所有人对于 web.py 因为各种原因都会有些痒。但是这不妨碍 web.py 的优秀和学术价值。
6.1.3. doudou 曰
{{{doudou doudou <[email protected]> hide details 1:04 pm (3 minutes ago)
reply-to [email protected] to [email protected] date Jul 10, 2007 1:04 PM subject Re: [python-chinese] 现在python的web框架这么多,有没有人能分析分析各自的优点缺点?
}}} 我学的不多,暂且比较一下吧。
- mod_python,直接用这个编程的人不多,如果你比较喜欢了解一些细节和直接控制这些细节的话,则是首选,与其他几种RAD框架相比mod_python简直就是汇编,可用的几个寄存器确保你学起来并不困难,但是写程序往往要写很多。
- cherrypy,我以前曾经很喜欢这个东西,也是我学过的第二个框架,简洁就是美,至今也没有发现什么很不爽的地方,只是他比mod_python高级不了多少,还是有很多东西需要自己重新写。那时同时也学了Cheetah,感觉不错。
- Pylons,一个恶梦,学起来并不简单,到了用的时候更是一塌糊涂。我还受到要求用它写过一个应用,后来因为Pylons的下属某个组件版本升级,乱写日志,就直接pass了。从此以后不用Pylons。
TurboGears,因为有cherrypy的基础,一直很想学,只是出于实在没空,其中的表单提交验证是很方便的东西。我涉足TG很浅,知道的也很少,不多做评论,不过由于是与Pylons一样的由多个组件构成,难保各个组件版本难以协调。即便是相同的TG版本也难以确保各个组件的版本与之前安装的都相同。
- web.py,用作嵌入式服务器和嵌入的WEB管理界面还可以,很方便。可以随着应用一起发布,无需安装,简直就是太完美了。不过说实在的,web.py的代码写的很巧妙,是我至今读过的很多WEB框架代码中最让我激动的,其中很多理念非常先进。
- django,最近正在学,开发速度较快,基本可以满足我的要求。只是,很多都是重新开发的,所以我以前积累的很多Python各类组件的知识都用不上了。
- 总体来说,推荐django,国内文档比较多,缺陷就是没有一本官方的书(写完的),而TG就有一本很不错的书。
- 如果你时间不是很急的话,推荐你先把web.py的代码看看,然后看看cherrypy的代码,再用Twisted自己实现一个小的框架,之后你就会发现那些框架原来差别并不大,学起来也可以用一些模式来学。
- 当然谈到自己实现一个框架,说实在的并不难,我以前那个Pylons的应用因为组件升级导致日志混乱之后,一气之下就用Twisted实现了一个小的框架。也许这也是为什么Python的框架这么多的原因,因为写起来并不难。我的这个框架在我的AMD 64双核台式机上面,每秒可以处理1500+个请求。同样的条件下web.py是720req/s,Pylons是610req/s。至于mod_python,尽管很熟,但是安装比较麻烦没有测试。
6.2. 综合对比
Re: 关于 Python 的 web 开发框架,应该选择哪个?
- limodou
web framework大多数从功能上都大同小异。从功能上分:zope/plone算大型的,而django, turbogears算是轻量级的。从学习曲线上分,zope/plone要长一些,而django, turbogears相对要短一些。对于django, turbogears来说,开发的理念有所不同,但功能是类似的。django所有东西都是自已开发的,象模板系统,url映射机制,ORM等。而turbogears则是许多相对成熟项目的集合,这一点与pylons也很象,如模板系统主要是kid,通过模板适配可以使用其它的模板(强调一下,django是松耦合的,许多组件也可以替换),web server组件使用cherrypy,ORM使用SQLObject(还可以使用SQLAlchemy)等等。关于这两种集成的方式,不同的人有不同的看法。有人认为turbogears是好的,因为没有重新造轮子。但有些人象我认为集中式更易管理和控制。所以关键看你认同哪一种设计理念。 对于ajax也有许多不同的声音。ajax本身可以与后台无关,它主要是在前端通过javascript, DOM来操纵前端数据,与后台交互。从这一点上,任何web framework都可以算是支持ajax。如果说不支持,那是从后台能否自动生成相应的html, javascript代码这一层来说的。turbogears嵌入了mochekit的js库的支持,可以通过python程序生成相应的js代码。django则是有人做过这样的工作,但要么不是成熟的东西,要么还没有成型。为什么会这样也与django的设计理念有关系。象turbogears,它的支持是针对不同的js库生成不同的包装,这样如果js库非常多,自然会有许多的包装,目前已经是这样的。而django在讨论是则不希望是这样,希望有一个中间层或无关层,但的确这一点很难。因此后来可能限定在了dojo,不过还没有相关的代码可以看到。只不过admin功能使用了dojo的一些东西。 还有pylons也很有特色。但对于我上人来说,我认为它太复杂了,不容易理解,所以也没有人研究过。目前国内对于django, turbogears, pylons都有人研究,从人数上看是比例依次递减。对于zope/plone则有专门的czug.org,有许多人在学习和研究。 总之,不同的框架从基本功能上是大同小异,在功能是各有特色的,设计理念上也是各有差异。选择一个框架不仅看它的功能是否满足,可能还有许多的因素,如人气,成熟度,是否有现实的应用,性能,设计理念等等。应用从方面进行考查,而且用着顺心可能更重要。象karrigell作为初学入门,或更轻量级的选择也是不错。 -- I like python!
从学习成本来看就三种层次: 1:Zope 系列的高成本复杂性平台,维护需要深入学习成本,带来整体的稳定; 2:Django 等的中等复杂度平台,通过各种组合,使用一定的框架概念,中度学习后,可以获得丰富的功能,和一定数量级别上的稳定; 3:web.py 类的极低学习成本,可以直接进入开发和同步运营,一切功能都可以自行快速开发出来,但是系统整体稳定性依赖开发人员的成熟度 平台的选择主要看你的应用原则,和运维手段,是想依赖平台的设计,还是开发人员的人品? 总之学习成本和对系统整体细节的掌控程度是呈反比的。
没有人否认 Zope-Plone 是最好的 base Python Web app. 平台, 但是, Zope2 也好 Zope 3 也好,都是有极高的学习曲线的, 就好象一个E国人,明知中文的唐诗是最优美的语言艺术, 但是他想恰当的引用诗句和真正可以自如的创造出古体诗的学习成本, 就好比我们要合理合法的深入使用Zope 平台和基于Zope进行二次开发的学习成本! 所以,就个人想立即享受,体验Python 的web app.应用开发,使用 Karrigell/web.py 吧! 想快速将Python 引入商业站点的快速开发,使用 Django/TurobGears 等等框架吧! 如果想真正服务永继的进行 web 服务的话,还是 Zope 3 吧!
-- ZoomQuiet
6.2.1. 关注Ajax 时
From: [email protected] <[email protected]> Mailed-By: googlegroups.com Reply-To: [email protected] To: "python.cn" <[email protected]> Date: Jun 9, 2006 2:15 PM Subject: [python-cn:10720] Re: 关于 Python 的 web 开发框架,应该选择哪个?
补充一点心得: 如果你的网页应用服务主要关注在 AJAX 应用, 大部分动作都用 javascript 在客户端完成, 只有 data 部分需要后端提供. 那么 TurboGears 是非常适用的选择. 1. 可以先用一般 serverside 开发方式写函式和建立网页应用服务原型 (prototype), 来测试你的网页应用服务该有的功能. @expose(format = ".template.pages") #资料以样版格式显示 def method(self): .... return dict{data=data} 因为 TurboGears 中从传入 serverside 的表单资料处理一致, 所以在 serverside 写的 code 完全可以继续使用, 不必为了支持 AJAX 重写, 很好的达到不重复自己(DRY)的效果. 2.import javascript library , 将资料改以 JSON 格式传到网页 from turbogears import mochikit ... @expose(format = ".template.pages") #资料以样版格式显示 @expose(format = "JSON") #资料以JSON格式显示 def method(self): .... return dict{data=data, scripty = mochikit} #在网页上 TurboGears 预先包好 mochikit, scriptaculous, plotkit 等 javascript 库, 使用时可以用程式呼叫, 预设可用 JSON 格式传输, 预设 mochikit 库提供相应资料处理支援. 3. 在 client 端用 javascript 处理 DOM 物件. 因为在开发的第一步时已经能将所需的资料, 传输内容等都处理好了, 能确信资料传输的正确性. 所以开发 javascript 时, 可以专注在网页内资料处理的部分. 在这时遇到 bug 的话也可以很放心地将可能的问题点缩小到单纯网页内资料处理的范围, 因而 AJAX 开发时最麻烦的交叉 debug 也变得更容易. 因此如果你的网页应用服务主要关注在 AJAX 应用, 那么 TurboGears 是非常适合的选择.
6.2.2. Django 体验
6.2.2.1. Romit~我对django的看法
Romit <[email protected]> reply-to [email protected], to python邮件列表 <[email protected]>, date Dec 13, 2007 11:05 PM subject [python-chinese] 我对django的看法
2006年末因为接手单位的网站,面对一个烂摊子,怎么能在短时间内让这个网站 焕然一新成为我面临的首要问题。 重造车轮式的方法显然是不可取的,更何况我也不是一个高手,所以就在互联网上 狂搜现成的框架。搜了一堆,首先是 zope,其次是plone,然后是什么tiger之类还有webpy之类,当然还有django。权衡 再三选择了django 第一、学习周期短 我花了2天多一点时间基本上就把django搞清楚了,而zope这个框架太庞大了,看 了一个多月没有搞出什么头绪来,plone 更是如此,tiger之类的呢完全是堆砌的产品(不喜欢,不过不知道这个东东怎么样) 第二、开发速度快 记得写第一个新闻发布系统的时候,大概就是一下午左右的样子,包括前端的AJAX 后台当然是自带的了,我觉得对很对象 我这种公司不给投入的人来说,无疑是一种福音,不管怎么样领导要的是一个结果。 第三、架构比较简单 规则表达式的url简单易用,基本功能一应俱全,特别是数据接口这块,特别适合 不熟悉数据库的人。经典的MVC式框架,对于 不是从事web开发的人员来说也是非常的清晰明了。 说完优点,说说缺点吧。 第一、管理界面比较呆滞,不容易扩展,听说下一个版本已经有所改善。 第二、django的应用管理不适合有变动需求的项目,为什么这么说呢,主要问题出 在django的模型和应用管理这块上,这两块 的功能实在太弱了,如果你不用管理平台这个问题压根就不存在。如果你使用它的 管理平台,对模型的更改首先是管理平台立即宕机, 其次是框架无法对数据库进行相应的更改,除非你对这个项目进行重新的部署,但 是一旦重新部署,你就会发现你的管理平台上所作的 任何权限的配置都无法生效,原因在于数据库内的权限系统已经被污染,除非你在 部署项目的时候,进入django的权限管理数据库系统内 首先清楚先前的项目。也有的网友提出了相应的解决方案: 1、导出数据 2、清除权限配置 3、部署应用 4、导入数据 也就是说django在应用管理上比较弱。 第三、原生数据库支持有点少,扩展的不在讨论范围之内。 目前还没有发现有性能方面的问题。
6.2.3. TurboGears vs Django
对比集中在高压力环境稳定性和sqlobject的发展结合上
6.2.3.1. gasolin 曰
{{{发件人: [email protected] <[email protected]> 回复: [email protected] 收件人: "python.cn" <[email protected]> 日期: 2005-9-19 下午9:32 主题: TurboGears vs Django }}}这几天从limodou兄的blog中看到 TurboGears 这个框架,看完演示教程后相当为之惊艳.
Django 跟 TurboGears 的出现提供了一个相当 pythonic 的解决方案 (python + HTML :D).
不需要使用资料库查询语言(SQL)或额外的资料库设计修改工具是一大特色.
TurboGears (Python) 是在 cherrypy +SQLObject等的基础之上整合相当成功的框架.
其计划的核心概念是不重复发明轮子, 而是把 python中的各轮子组成有用的框架.计划主要的工作是提供简化的安装, 设定, 操作,与文件.
之前 Ruby on rails 超热的时候似乎 python 社群有个 SUBWAY计划想达成类似的事情,但一听就知道是想复制 ROR 的计划,并未提出相当的成果.
两者较不同的是 Django提供预设的资料库增删修改介面, 而 TGP似乎还没发展这块.
比起 Django 来说, TurboGears 更吸引我的是整合 AJAX 支援,
Django 跟 TurboGears 相比无论安装, 使用上都复杂许多,而 Django 从头开发也意味着目前 python web开发社群要使用这框架也得多花费心力去学习.
TGP 是由 python script 组成的 controller 呼叫 SQLObject来读出资料库中的资料,再以字典形式传值到样板中当作动态语言的变数.
达成资料库(model)->controller->template (View) 的 MVC 架构
传出的格式如
{data=content, pagename=page.pagename}
这样一次收集所有用到的参数,接收用
<div py:replace="data"/> Page text goes here. </div>
这样在标签中加"py:replace"的格式插入参数,
Ruby on rails 或 Django 每加一页新的资料, 要处理的 MVC关连似乎不及TurboGears 承袭 cherrypy架构(不知有无说错?)的简单明了
TurboGears 教程中是由单一的 controller (标准的 python class) 呼叫 SQLObject来读出资料库中的资料, 再以字典形式传值到样板中当作动态语言的变数.
达成资料库(model)--controller--template (View) 的 MVC 架构.
由 controller 传出的格式如 {data=content,pagename=page.pagename}
一次收集网页样板将用到的 data 跟pagename 参数.
网页样板 template 接收用
<div py:replace="data">内容显示在这里</div>
实际显示时会将"内容显示在这里"这段替换成资料集"data"中的内容.
要在网页样板中调用这几个参数有两个方式.
第一种是可以在标签中加py:replace="data", 来插入 data字典参数;
或是使用类似一般动态语言给参数的方式 ${data} 插入data 字典参数.
- 注意第二种的格式还是跟 python调用字典的感觉很像.
间中用到的 HTML, ini 都算是基本的内容,用起来没什么要另外学东西的负担.
Django (或 Ruby on rails)每加一页新的资料,都要分别处理对应的 controller.关连似乎不及 TurboGears 承袭 cherrypy 架构可使用单一controller 的简单明了(不知有无说错?)
因此我认为相比之下 TurboGears 成功的机率更大些.
6.2.3.2. limodou 曰
{{{回复: [email protected] 收件人: python-chinese列表 <[email protected]> 日期: 2005-11-14 上午10:24 主题: [python-chinese] Django vs. TurboGears }}} [wiki:PyCNmail/2005-November/019026.html Django vs. TurboGears]
看到列表中讨论 Django 和 TurboGears 的多了起来,我想就这两个web framework提出自已的一些看法,因为哪个都算不上精通,只是对某些方面多一些罢了,至今天除了按照django的教程做了一下,某它的就没做过。TurboGears方面也只是学过CherryPy而已,不过我从我个人的关注角度出来,希望对它们进行比较一下,大家可以补充,让比较更客观。另外因为我对DjanGo关注稍多一些,可能对于turbogears有些不正确的观点,请大家见谅。
DjanGo比 TurboGears 的优点
- 自动的admin界面,有用户和组的管理,这些代码不用你写了
- generic view,减少你写view的代码,模板当然还是要的
- 模块及模板均支持i18n。
- url采用正则表达示很有创意,这样可以规则你的url。另外通过正则表达式可以构造与方法调用无直接关系的链接形式,搜索引擎支持好。
DjanGo的模板还可以自已扩展,很有趣,可以增加新的tag和filter,而且写起来挺简单。
- 有middleware,可以自已编写
- 应用安装方便
- 开发团队集中,目标一致
- 已经有网站的应用
TurboGears 比 DjanGo的优点
共同的优点:
- 文档做得都不错
- 都象ROR一样提供相应的命令行工具
我的感觉是: -- ZoomQuiet
- TG 是聪明的大杂烩,但是每种主料发展的不均衡一定会影响到TG的,当然集成 Ajax 是非常吸引人的
- Dj 是一个美妙的新轮子 MTV 非常炫,但是远离了Pythonic, 回到Unix 神秘的命令行时代了,而且DB 操作调试,更加没谱了……
这两天在看 TG 感觉到 TG并没有因为 它的杂而影响到他,相反的很多组建开始依赖 TG 来开发了,而且 TG 开始引入 Plugin的概念了,原来集成在 tg里面的 kid 模板组建 从 r459 开始分离出了TG 这样 TG现在就有了很多的 Template engine 了 TurboCheetah ,TurboStan TurboKid,TurboZpt ,这些个 Template engine 都会为 TG 带来更多的新鲜血液,吸引更多的开发者. 还有 ORM ,估计 Kevin Dangoor 也会渐渐的将 SQLObject作为 plugin来集成在 TG里面了,这样更多 好东西都会慢慢加入 TG了,但是估计CherryPy是换不掉了,现在看tg的maillist Kevin Dangoor 和 Cherrypy的团队合作很密切.呵呵,然后就是很让人期待的事情了 Kevin 打算在 pycon2006之前发布 1.0版本,现在每天就是看 TurboGears Repository Commits 都有些什么更新.
还有 TG的 Toolbox组件也非常的让人期待 modelDesigner的出现使得建模更加的快速和简单了,真正突显出了 TG 的快速开发. by bib
6.2.3.3. InterMa 补充
{{{节译: 主要比对方面:
- 基本框架思想
- URL 调度系统
- 模板系统
- ORM 支持
- 表单处理
- 扩展类型应用
- 高级应用
- 框架已知缺点
- 框架未来发展
}}}
- 大概意思是褒Dj贬Tg,不过个人还是比较喜欢Tg,希望她能度过难关。
是也乎,俺也是看好TG ,奈何未成气候 -- ZoomQuiet
寻找类似ROR的web框架的讨论:/SimilarToRor--TomZ
7. 自由评注
频率受到Spamer 攻击!070528关闭自由注释功能
8. P2P
KenoSis -- 构建p2p网络的基础框架
9. P4EE
Python 企业环境应用探讨 Python for Enterprise Environment
PEAK- The Python Enterprise Application Kit.htm
PyTwisted - 高性能网络通讯协议支持包!
PyUSS - HD 提议的"高性能分布式网络存储系统"
解读_PyTwisted - HD PyTwisted 技术文章汇编 转自 http://blog.huangdong.com
/SSO -- 统一登录
9.1. mod_python
与Apache 紧密结合的支持组件!终于可以完好运行了
modpythoncn -- oatil, eddyxu 贡献
9.2. Zope
ZopeSpread -- Zope 平台推广文章
ZopeX3--全新开发的应用平台!
- 但是!和ZOPE2的变化实在是太大了。难怪ZOPE3从2001年开始开发,一直到现在还有release呢,整个架构变了,连使用习惯都变了,对于想转到Zope3开发的人员来说是一个比较麻烦的问题。
Zope3Book -- 紧跟最新成果的翻译项目!honeyday 发起!
三十分钟学会Zope3 -- 野火星兔
Zope2Book -- 杜文山版!
MyZopeBook -- 我们翻译的Zope 相关文档
CMF -- 内容管理框架
Plone -- 集成信息平台
PloneSpread -- Plone 推广文章
061111 SPUG 聚会资料:看图识Plone
LearningZodb - ZODB学习全记录 -- hoxide 发起
9.3. Dabo
DaBo -- 又一个默默发展的快速开发平台!
10. Pythonic 模板
Contents
10.1. GenShi
- 特点:解释型模板,纯粹面向 xml,流式的处理机制,能够嵌入 python 语句和表达式,提供强大的功能。
- 从 Kid 发展而来,比 Kid 更灵活,性能也更好,实现部分 XPath,XInclude 规范。
TurboGears 默认的模板引擎将从 Kid 转为 GenShi 。
10.2. MaKo
- 特点:编译型模板,卓越的性能,将 Python 语言优雅得植入模板中,功能强大。
由 Myghty 发展而来,是对 Myghty 的重新设计和重新实现,类似 GenShi 和 Kid 的关系。
10.3. JinJa
特点:编译型模板,类似 django 模板的简洁语法,适合网页设计师使用。继承和发扬了 django 模板在安全性方面(SandBox)的考量,限制模板的能力,有专门机制防止模板修改数据和访问危险代码!
与 django 模板主要区别在于:编译 vs 解释,macro,支持 python 表达式。另外还有一些细节上的区别,见:Differences To Django Templates
根据 FAQ,性能大概三倍低于 mako,两倍高于 django 模板。
10.4. ClearSilver
ClearSilver是一个高性能的模版系统,让我们看看他的使用网站,就知道他的表现有多好。
- Bloglines
- Google Groups
- Yahoo Groups
10.5. 印度豹
Cheetah - http://www.unrealtower.org/mycheetah
CheetahTemplateOrg -- 一个历史悠久的JAVA 模板系统的衍生,可以生成一切文本文件
10.6. Myghty Google 的利器
MyghtyOrg -- 一个高速模板系统,几乎可以独立作为web 应用平台来使了
10.7. Kid
Kid 是一种简单的基于 XML 的模板语言,它使用嵌入的 Python 语句来对某些元素进行处理,它的语法借鉴了许多现存的模板语言,诸如 XSLT、TAL、PHP等等。
Kid 的设计目标是为了简化 Python 对 XML 文档的处理。同其它 XML 工具相比:
SAX、DOM、ElementTree 等 API 可以保证输出是组织良好的,但要求文档必须用 Python 创建。
- Cheetah、PTL 等模板语言很容易使用,但不能保证输出结果是组织良好的。
- XSLT 提供了许多函数来产生良好的 XML 文档,但要求所有输入必须是 XML 文档格式,用起来也不怎么简便。
Kid 则试图结合所有上述技术的优点。
Kid 可以用来产生任何形式的 XML 文档,包括 XHTML、RSS、Atom、FOAF、RDF、XBEL、XSLT、RelaxNG、Schematron、SOAP 等等。
参考:肯定来过的学习笔记。
10.8. 其它
PyWork - http://pywork.sourceforge.net
Subway - http://subway.python-hosting.com/
Spyce - http://spyce.sf.net
- ZQ 收集对比
http://floss.zoomquiet.org 访问路径:->org.python->WebApp.->Py模板系统
10.9. 讨论
自动Spamer 攻击,无奈关闭自由评注