龙空技术网

22个受欢迎的Python不同类型开源框架

虎钧 382

前言:

现在大家对“python开源服务器”可能比较着重,姐妹们都想要剖析一些“python开源服务器”的相关内容。那么小编也在网上网罗了一些有关“python开源服务器””的相关资讯,希望小伙伴们能喜欢,小伙伴们一起来学习一下吧!

以下面是我从网上整理的最受欢迎的Python开源框架。这些框架包括事件Web开发,I/O,OLAP,高性能网络通信,测试,爬虫等。

一、Python Web框架

Django: Python Web应用开发框架
链接:
Django 应该是最出名的Python框架,GAE甚至Erlang都有框架受它影响。Django是走大而全的方向,它最出名的是其全自动化的管理后台:只需要使用起ORM,做简单的对象定义,它就能自动生成数据库结构、以及全功能的管理后台。

Flask:一个用Python编写的轻量级Web应用框架
链接:
Flask是一个使用Python编写的轻量级Web应用框架。基于Werkzeug WSGI工具箱和Jinja2 模板引擎。Flask也被称为“microframework”,因为它使用简单的核心,用extension增加其他功能。Flask没有默认使用的数据库、窗体验证工具。

Bottle: 微型Python Web框架
链接:
Bottle是一个简单高效的遵循WSGI的微型python Web框架。说微型,是因为它只有一个文件,除Python标准库外,它不依赖于任何第三方模块。

webpy: 轻量级的Python Web框架
链接:
webpy的设计理念力求精简(Keep it simple and powerful),源码很简短,只提供一个框架所必须的东西,不依赖大量的第三方模块,它没有URL路由、没有模板也没有数据库的访问

Web2py:全栈式Web框架
链接:
Web2py是一个为Python语言提供的全功能Web应用框架,旨在敏捷快速的开发Web应用,具有快速、安全以及可移植的数据库驱动的应用,兼容Google App Engine。

CubicWeb:面向对象设计的语义Web应用程序框架
链接:
一个有趣的系统,强调使用抽象和可重用的代码块称为“多维数据集”,但对于某些开发人员来说可能过于抽象或特殊。

Tornado:异步非阻塞IO的Python Web框架
链接:
Tornado的全称是Torado Web Server,从名字上看就可知道它可以用作Web服务器,但同时它也是一个Python Web的开发框架。最初是在FriendFeed公司的网站上使用,FaceBook收购了之后便开源了出来。


二、Python 事件I/O框架

Diesel:基于Greenlet的事件I/O框架
链接:
Diesel提供一个整洁的API来编写网络客户端和服务器。支持TCP和UDP。


三、Python OLAP框架

Cubes:轻量级Python OLAP框架
链接:
Cubes是一个轻量级Python框架,包含OLAP、多维数据分析和浏览聚合数据(aggregated data)等工具。


四、Python 网络框架

Zerorpc:基于ZeroMQ的高性能分布式RPC框架
链接:
Zerorpc是一个基于ZeroMQ和MessagePack开发的远程过程调用协议(RPC)实现。和 Zerorpc 一起使用的 Service API 被称为 zeroservice。Zerorpc 可以通过编程或命令行方式调用。

Falcon:构建云API和网络应用后端的高性能Python框架
链接:
Falcon是一个构建云API的高性能Python框架,它鼓励使用REST架构风格,尽可能以最少的力气做最多的事情。

Twisted:底层自定义协议网络框架
链接:
Twisted是一个高性能的编程框架。在不同的操作系统平台上,Twisted利用不同的底层技术实现了高效能通信


五、Python 测试框架

selenium:Web的自动化测试工具
链接:
一个用电脑模拟人操作浏览器网页,最初是为网站自动化测试而开发的,类型像我们玩游戏用的按键精灵,可以按指定的命令自动操作,不同是Selenium 可以直接运行在浏览器上,它支持所有主流的浏览器(包括PhantomJS这些无界面的浏览器)。

unittest:标准库中自带的单元测试框架
链接:
unittest 单元测试框架是受到 JUnit 的启发,与其他语言中的主流单元测试框架有着相似的风格。其支持测试自动化,配置共享和关机代码测试。支持将测试样例聚合到测试集中,并将测试与报告框架独立。

Robot Framework:作为最重要的Python测试框架之一
链接:
Robot Framework主要被用在测试驱动(test-driven)类型的开发与验收中。虽然是由Python开发而来,但是它也可以在基于.Net的IronPython和基于Java的Jython上运行。同时,作为一个Python框架,Robot还能够兼容诸如Windows、MacOS、以及Linux等平台

Pytest:适用于多种软件测试的Pytest
链接:
凭借着其开源和易学的特点,该工具经常被QA(质量分析)团队、开发团队、个人团队、以及各种开源项目所使用。鉴于Pytest具有“断言重写(assert rewriting)”之类的实用功能,许多大型互联网应用,如Dropbox和Mozilla,都已经从下面将要提到的unittest(Pyunit)切换到了Pytest之上。


六、Python 爬虫框架

Scrapy:Python的爬虫框架
链接:
Scrapy是一个使用Python编写的,轻量级的,简单轻巧,并且使用起来非常的方便。

PySpider:binux做的一个爬虫架构
链接:
强大的网络爬虫系统,并自带有强大的webUI,分布式架构,支持多种数据库后端。

Portia:一个开源可视化爬虫工具
链接:
可以让使用者在不需要任何编程知识的情况下爬取网站。简单地注释自己感兴趣的页面,Portia将创建一个蜘蛛来从类似的页面提取数据。


七、其他

Kartograph.py:创造矢量地图的轻量级Python框架
链接:
Kartograph是一个Python库,用来为ESRI生成SVG地图。Kartograph.py目前仍处于beta阶段,你可以在virtualenv环境下来测试。

Pulsar:Python的事件驱动并发框架
链接:
Pulsar是一个事件驱动的并发框架,有了pulsar,你可以写出在不同进程或线程中运行一个或多个活动的异步服务器。

Dpark:Python版的Spark
链接:
DPark是Spark的Python克隆,是一个Python实现的分布式计算框架,可以非常方便地实现大规模数据处理和迭代计算。DPark由豆瓣实现,目前豆瓣内部的绝大多数数据分析都使用DPark完成,正日趋完善。


标签: #python开源服务器