Web Frameworks for Python

Web Frameworks for Python

一篇很详细很全面介绍python下的web framework的文章,来自于python官网。

A Web framework is a collection of packages or modules which allow developers to write Web applications (seeWebApplications) or services without having to handle such low-level details as protocols, sockets or process/thread management.

The majority of Web frameworks are exclusively server-side technology, although, with the increased prevalence of AJAX, some Web frameworks are beginning to include AJAX code that helps developers with the particularly tricky task of programming (client-side) the user's browser. At the extreme end of the client-side Web Frameworks is technology that can use the web browser as a full-blown application execution environment (a la gmail for example): seeWeb Browser Programming for details.

As a developer using a framework, you typically write code which conforms to some kind of conventions that lets you "plug in" to the framework, delegating responsibility for the communications, infrastructure and low-level stuff to the framework while concentrating on the logic of the application in your own code. This "plugging in" aspect of Web development is often seen as being in opposition to the classical distinction between programs and libraries, and the notion of a "mainloop" dispatching events to application code is very similar to that found in GUI programming.

Generally, frameworks provide support for a number of activities such as interpreting requests (getting form parameters, handling cookies and sessions), producing responses (presenting data as HTML or in other formats), storing data persistently, and so on. Since a non-trivial Web application will require a number of different kinds of abstractions, often stacked upon each other, those frameworks which attempt to provide a complete solution for applications are often known asfull-stack frameworks in that they attempt to supply components for each layer in the stack.

Many frameworks now provide an element of customization in their support for the above activities and abstractions, utilizingcomponents in that they provide abstractions only for certain specific things. As a result, it can be possible for you to build your own full-stack framework almost entirely from existing components.

Emerging Web Frameworks

However, to elucidate key differences opposing full-stack frameworks andtraditional (or emerging) web frameworks is left as an exercise to the reader...

In particular, emerging web toolkits provides new areas of functionality over traditional ones (Zope)

Popular Full-Stack Frameworks

A web application may use a combination of a base HTTP application server, a storage mechanism such as a database, a template engine, a request dispatcher, an authentication module and an AJAX toolkit. These can be individual components or be provided together in a high-level framework.

These are the most popular high-level frameworks. Many of them include components listed on theWebComponents page.

  • Django (1.0.2 Released 2008-11-18) a high-level Python Web framework that encourages rapid development and clean, pragmatic design

  • Pylons (0.9.6.2 Released 2008-05-28) a lightweight Web framework emphasizing flexibility and rapid development. It combines the very best ideas from the worlds of Ruby, Python and Perl, providing a structured but extremely flexible Python Web framework. It's also one of the first projects to leverage the emerging WSGI standard, which allows extensive re-use and flexibility but only if you need it. Out of the box, Pylons aims to make Web development fast, flexible and easy. Pylons is built on top of Paste (see below).

  • TurboGears (1.0.7 Released 2008-09-15) the rapid Web development megaframework you've been looking for. CombinesCherryPy, Kid, SQLObject andMochiKit. After reviewing the website check out:QuickStart Manual

  • web2py (1.49.1 Released 2008-11-11) Everything in one package with no dependencies. Development, deployment, debugging, testing, database administration and maintenance of applications can be done via the provided web interface. web2py has no configuration files, requires no installation, can run off a USB drive. web2py uses Python for the Model, the Views and the Controllers, has a built-in ticketing system to manage errors, an internationalization engine, works with MySQL, PostgreSQL, SQLite , Oracle, MSSQL and the Google App Engine via an ORM abstraction layer. web2py includes libraries to handle HTML/XML, RSS, ATOM, CSV, RTF, JSON, AJAX, XMLRPC, WIKI markup. Production ready, capable of upload/download of very large files, and always backward compatible.

  • Grok (0.14 Released 2008-09-29) is built on the existing Zope 3 libraries, but aims to provide an easier learning curve and a more agile development experience. It does this by placing an emphasis on convention over configuration and DRY (Don't Repeat Yourself).

  • Zope (2.10.7 Released 2008-10-25, 2.11.2 Released 2008-25-10, 3.3.1 Released 2007-01-14, Zope 3.4.0c1 Released 2008-01-31) Being the grandaddy of Python web frameworks, Zope has grown into a family of frameworks over the years. Zope 1 was released in 1999. Zope 2 is both a web framework and a general purpose application server, today it is primarily used byContentManagementSystems. Zope 3 is both a standalone framework and a collection of related libraries, which are also included with newer releases of Zope 2. All of the Zope frameworks include the ZODB, an object database for Python.

See below for some other arguably less popular full-stack frameworks.

Content Management Systems

Content management systems (CMS) often allow you to build application like functionality upon them and typically provide many of the facilities seen in full-stack frameworks. SeeContentManagementSystems for more details.

Web Components

Some frameworks promote interoperable components for things like templating/output and authentication/authorization, and so you might see users of different frameworks actually using the same component or library. SeeWebComponents for details of such components.

Browser Programming (aka web client frameworks)

The use of AJAX for Web development is on the increase, yet, because AJAX is written in javascript - a full-blown programming language in its own right - typical Web Frameworks rightly steer well clear of offering "fully featured" AJAX integration. Some of the more advanced AJAX frameworks will provide limited features such as AJAX-inspired popups, menus, auto-completion listboxes, but these are provided "as-is", for automatic-integration into the web application, rather than allowing the developer to write their own AJAX widgets.

This "server-side-only" style of web development is beginning to put a strain on developers and on the Web frameworks themselves. Fortunately, however, pythonic answers exist in the forms of compiling python code into AJAX; embedding a python interpreter into the web browser; or turning things on their head and using web browser "engines" that are manipulated from python rather than using a full-blown dedicated Web Browser. SeeWeb Browser Programming for details.

The addition of this "client-side" technology allows the developer to take a hybrid / dual approach to Web development, by treating the Web browser as a tool that can execute full-blown (albeit restricted) applications instead of as just a "thin client" / "HTML display mechanism", thus reducing the complexity of server-side Web development.

The ideal situation, to have a meta-framework where code written in python can seamlessly be compiled to client-side AJAX and can seamlessly target a wide range of server-side Web Frameworks, has yet to emerge as free software.

Other Full-Stack Frameworks

These frameworks also provide most, if not all of the technology stack. However, they are regarded as not being as popular as the frameworks listed above.

  • Enamel - an abstraction layer over Twisted, Nevow, Formal and SQLAlchemy to converge their concepts under a single framework

  • Gizmo(QP) (0.7 Released 2007-04-17) extends QP (see below) adding functionality to help with building rich and exacting web interfaces. Includes a Form module that supports (redundant) automatically generated client-side field validation as well as additional json callbacks.

  • Glashammer (0.1.3 Released 2008-08-11) is a full stack Python web framework with an emphasis on simplicity, flexibility, and extensibility. It is built atop excellent components and reinvents zero wheels. WSGI, routing, templating, forms, data, plugins, config, events, SQLAlchemy, Storm, Couchdb, OpenID,AppEngine, Jquery, etc.

  • Karrigell (2.4.0 Released 2008-04-12) is a flexible Python web framework, with a clear and intuitive syntax. It is independent from any database, ORM or templating engine, and lets the programmer choose between a variety of coding styles.

  • notmm - A general purpose and heterogenous web toolkit on top of Django.

  • Porcupine (0.5.2 Released 2008-12-04) provides everything you need for building modern data-centric Web 2.0 applications, including the QuiX Javascript toolkit and the Porcupine Object Query Langguage (POQL).

  • Pyroxide is built atop Apache's mod_python. It uses the MVC (model-view-controller) pattern and other classic object oriented patterns throughout. It abstracts the mod_python layer presenting a very sensible object oriented framework so that the developer deals with HTTP Requests, HTTP Responses, Page Controllers, Views and domain model objects. It integrates very well with AJAX frameworks such as Prototype and Mochikit. It comes with an elegent ORM framework and runs with Zope Page Templates (Simpletal project) out of the box.

  • QP (2.1 Released 2008-12-03) a package for defining and running multiple Web applications that are based on Durus for persistence, offering standard persistent Session and User classes, easy interactive database sessions, and unicode QPY for assembling html. Packages require and run on Python >= 2.4 and yes that includes Python 3.0!

  • SkunkWeb (3.4.0 Released 2004-09-10)

  • Spyce (2.1.3 Released 2006-11-17)

  • web.py (0.23 Released 2008-01-19) Think about the ideal way to write a Web app. Write the code to make it happen.

  • Webware (1.0 Released 2008-11-29) is a suite of Python packages and tools for developing object-oriented, Web-based applications

Basic Frameworks

These projects provide the base "application server", either running as its own independent process, upon Apache or in other environments. On many of these you can then introduce your own choice of templating engines and other components to run on top, although some may provide technologies for parts of the technology stack.

  • AppWsgi - illustration of building your own ajax framework running on a mod_wsgi apache server

  • CherryPy (3.1.0 Released 2008-06-30) is a pythonic, object-oriented HTTP framework.CherryPy powered web applications are in fact stand-alone Python applications embedding their own multi-threaded web server.TurboGears (see above) also uses CherryPy.

  • Python Paste (1.6 Released 2008-01-04) brings consistency to Python Web development and Web application installation, providing tools for both developers and system administrators. Also, Pylons (see above) is built on top of Paste.

  • PyWebLib (1.3.4) - provides support for forms and sessions; used to implement web2ldap

  • WebStack (1.2.7 Released 2007-10-29) - very lightweight, requiring layers of extra technology (eg.XSLTools and others) to match full-stack frameworks in feature comparisons

Basic Frameworks Providing Templating

  • Albatross (1.36 Released 2007-03-19) a small and flexible Python toolkit for developing highly stateful Web applications.

  • Aquarium (2.2.1 Released 2005-04-21) offers convenient libraries, tight integration with Cheetah, adaptors for various Web environments

  • Divmod Nevow (0.9.0 Released 2006-06-12) a comprehensive library including a resource model encouraging the separation of application and presentation logic, a markup system with support for designer-friendly XHTML templates and pure-Python templates, and a robust AJAX-like API (Divmod Athena) which supports the creation of highly dynamic Web pages in a structured manner.

  • JOTWeb2 (1.10 Released 2005-12-30) developing dynamic Web applications using HTML and TAL/TALES/METAL for templating

  • Python Servlet Engine (3.0.4 Released 2006-02-17) PSE parses your templates into byte compiled "servlets" to produce Web pages that run fast

  • Quixote (2.5 Released 2007-11-16) Allows developers to develop dynamic Web sites while using as much of their existing Python knowledge as possible

  • Snakelets (1.44 Released 2006-06-04) simple-to-use Python Web application server

  • Spark (0.2.1 Released 2006-9-15) Fast and lightweight Web kit. Supports mod_python, WSGI, Twisted.

  • Wasp (2.00 Released 2007.07) - supports command-line, CGI and embedded web server modes, with templating, session mechanism and other modules emphasizing ease of use and familiar paradigms.

Discontinued/Inactive Frameworks

The following frameworks are either discontinued, in that their developers may have stated that they no longer maintain the code, or appear to be inactively developed or maintained, in that the Web site for the project has remained unchanged for an extended period of time.

  • 4Suite (the server product seems to receive relatively infrequent updates and the site is often down)

  • maki (developers no longer use the product)

  • Python Server Pages, or PSP (old Web site from 1999)

  • Crusader is a powerful application server for Python based upon a scalable, extensible and easy-to-use general purpose server framework.

  • Cymbeline (1.3.1 Released 2005-12-09) an application server framework, including functionality such as DB and arbitrary object pooling, Web servers, persistant object repository, and a text console

Books and Articles

  • Steve Holden wrote a book on Python Web Programming. The book from John Goerzen,Foundations of Python Network Programming, can also be useful. O'Reilly'sProgramming Python 3rd Edition has 500 pages on Internet programming, including 250 on Web scripting. Finally, check out the Web Programming chapter in Core Python Programming by Wesley Chun -- there is also a small section elsewhere on Web APIs.

  • Developing With Mod_Python - an article on Mod_Python programming with Cheetah Templates and MySQL. Contains code samples.

  • The Zope 3 Quick Start Guide gives a short introduction to Zope 3.

Editorial Note

The above lists should be arranged in ascending alphabetical order - please respect this when adding new solutions. When specifying release dates please use the format YYYY-MM-DD.

Some special notes to contributors to this page who like to assume an advocacy position when "reorganising" the content:

  • Do not remove editorial guidelines: when people do this it not only indicates that they do not care about such guidelines, but it also leads others to believe that the page never had any structure or purpose.

  • If you must change the categories used on this page, at least attempt to assign all frameworks to meaningful categories.Do not invent special categories in order to elevate the profile of certain projects.Do not merge categories and put frameworks into a miscellaneous category.

  • Do not add links to projects unless they are Web frameworks. Instead, use theWebComponents,WebServers,Templating pages, or any page referenced byWebProgramming.

  • Some frameworks are not actively developed or maintained. Do not just move entries into the "Discontinued/Inactive Frameworks" section without at least doing some investigation first.

And some basic editing advice: use the preview button when making edits, rather than leaving tens of micro-changes in the history.



依大致国人关注度进行排序

  • Python + Web ~SWiK 的收集和整理,,,

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

  • Django: Removing The Magic

2.3. TurboGears

  • TurboGears -- 超强涡轮!

    • TurboGearStepByStep -- 等待开启的体验式学习教程!

2.4. Karrigell

  • KarriGell -- 永远安心工作的“推车”

  • KarrigellQuickIn --- 快速体验

    • KarrigellTutorial -- Karrigell 教程

2.5. web2py

  • 主页~ 号称企业级的web framework

  • Web2Py ~ 我们的体验!

2.6. web.py

  • webpy.org

  • web.py

2.7. Pylons

  • Pylons主页

  • PylonsQuickIn

  • Pylons

    • Quick Wiki Tutorial

2.8. Quixote.堂吉诃德

  • QuixoteQuickIn --- 快速进入 无畏的骑士!豆瓣 的主要动力系统!

2.9. Paste

  • PasteQuickIn

  • Paste

2.10. Myghty

  • MyghtyOrg -- 模板核心的框架

2.11. Zope系列

基础宣传
  • 面向对象的Web应用平台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

  • Nuxeo CPS

  • Silva

{ ZopeEnv }e

3. 国人框架

3.1. Uliweb

  • Uliweb -- 由limodou发起,多人参加的开源web框架。
    • 集众家之长的框架!
    • 官方网站

3.2. 悟空智轮

  • WukooPy -- lihui 混合 Karrigell 和 Quixote 创造的 一个应用轮子

    • 哈哈哈!别直接龙了,叫 蟒龙是也乎?

4. CMS框架

PyCMS系列收集

4.1. itools

  • itools

4.2. payago

  • payago

4.3. pylucid

  • [http://www.pylucid.org/ pylucid

4.4. skeletonz

  • skeletonz

4.5. teeny_tiny_cms

  • teeny_tiny_cms

5. 边缘框架

5.1. Dabo

  • DaBo -- 又一个默默发展的快速开发平台!

5.2. Storm

  • https://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

  • AquaRium

5.9. RhubarbTart

RhubarbTart



Pythonic Web 应用平台对比

分类: 网络相关 python 770人阅读 评论(0) 收藏 举报

排序原则

平台

有大把時間做企業級應用

plone,zope

適合 python 專家用

pylons, webpy, twisted.web, zope

追求一體框架

django, zope/plone, karingel

適合快速上手

karingel, cherrypy. turbogears

快速 CMS

django

支援度

django, turbogears, pylons, zope/plone

框架自由度

pylons, turbogears

一般用途

django, turbogears, pylons

文檔優勢

django, turbogears, pylons

有 Rails 背景

pylons, turbogears

有 AJAX/javascript helper/widgets

turbogears/pylons

WSGI 支持度

pylons, turbogears(django努力中)

JSON(AJAX server side)

turbogears

並用 flash/flex

turbogears

 

{ /PyWebMatrix } e

 

 

1.1. 再次综合对比

 

 

1.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程序员可能很难再去投入到一个看上去复杂的体系中了.我可能就是这样的.

 

1.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 的优秀和学术价值。

 

1.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,尽管很熟,但是安装比较麻烦没有测试。

 

1.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!
    
    • ZoomQuiet

      从学习成本来看就三种层次:
      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

 

1.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 是非常适合的选择.

 

 

1.2.2. Django 体验

 

 

1.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在应用管理上比较弱。
第三、原生数据库支持有点少,扩展的不在讨论范围之内。

目前还没有发现有性能方面的问题。

 

 

1.2.3. TurboGears vs Django

 

对比集中在高压力环境稳定性sqlobject的发展结合

 

1.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中的各轮子组成有用的框架.计划主要的工作是提供简化的安装, 设定, 操作,与文件.

  • 我们的 WuKooPy 也是这意思,不过关注的深度比较浅 -- ZoomQuiet

之前 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 成功的机率更大些.

{ TGvsDjGasolin } e

 

 

1.2.3.2. limodou 曰

 

 

 

回复: [email protected] 
收件人: python-chinese列表 <[email protected]>
日期: 2005-11-14 上午10:24
主题: [python-chinese] Django vs. TurboGears

Django vs. TurboGears

看到列表中讨论 Django 和 TurboGears 的多了起来,我想就这两个web framework提出自已的一些看法,因为哪个都算不上精通,只是对某些方面多一些罢了,至今天除了按照django的教程做了一下,某它的就没做过。TurboGears方面也只是学过CherryPy而已,不过我从我个人的关注角度出来,希望对它们进行比较一下,大家可以补充,让比较更客观。另外因为我对DjanGo关注稍多一些,可能对于turbogears有些不正确的观点,请大家见谅。

  • DjanGo比 TurboGears 的优点

    1. 自动的admin界面,有用户和组的管理,这些代码不用你写了
    2. generic view,减少你写view的代码,模板当然还是要的
    3. 模块及模板均支持i18n。
    4. url采用正则表达示很有创意,这样可以规则你的url。另外通过正则表达式可以构造与方法调用无直接关系的链接形式,搜索引擎支持好。
    5. DjanGo的模板还可以自已扩展,很有趣,可以增加新的tag和filter,而且写起来挺简单。

    6. 有middleware,可以自已编写
    7. 应用安装方便
    8. 开发团队集中,目标一致
    9. 已经有网站的应用
  • TurboGears 比 DjanGo的优点

    1. ORM模块采用sqlobject,比DjanGo中的要成熟

    2. 支持ajax
    3. 充分利用了setuptools工具
    4. 宣传力度大,人数多,相对DjanGo活跃

  • 共同的优点:

    1. 文档做得都不错
    2. 都象ROR一样提供相应的命令行工具
{ TGvsDjLimodou } e

 

 

  • 我的感觉是: -- 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

{ PyWebFrameDiscuss } e

 

 

1.2.3.3. InterMa 补充

 

  • 一篇好文:Python web development and frameworks in 2007

 

节译: 
主要比对方面:
    * 基本框架思想
    * URL 调度系统
    * 模板系统
    * ORM 支持
    * 表单处理
    * 扩展类型应用
    * 高级应用
    * 框架已知缺点
    * 框架未来发展

 

  • 大概意思是褒Dj贬Tg,不过个人还是比较喜欢Tg,希望她能度过难关。
  • 是也乎,俺也是看好TG ,奈何未成气候 -- ZoomQuiet

寻找类似ROR的web框架的讨论:[[/SimilarToRor]]--TomZ

 

2. 自由评注



你可能感兴趣的:(Web,框架,django,python,python,Pylons,frameworks,网络相关)