Base PyQt4, Simple Web APP Framwork
长时间以来,一直针对Linux 服务器开发后台程序,每天面对的是黑框框,输出只有日志文件。偶尔需要模拟客户端测试,要么是写几行php代码,在浏览器上点一点,要么是写个小Python脚本在shell中执行一下。写了一些测试用的小脚本以后,越来越钟爱这种脚本测试方式了。想到什么测试case,三下五除二改改脚本就能测了。测试小脚本多多少少也写了十来个了。其实自己Php和Python的底子都不好,只是略懂一二,居然大部分问题都能google一下轻松解决,主要是也不需要使用神马高级特性哈哈。
最近的项目的测试却让我犯难了,要搞GUI程序!哥身为Linux服务器下C++程序员,向来不屑写GUI,也闲麻烦(也闲自己不太会哈哈)。我们开发了一个基于地图的游戏,现在一是要测试稳定性模拟N个用户随机的移动,二是测试服务器性能,当用户相对集中在地图上某个区域时,服务器的响应效率如何。这个是当前最主要的需求,我们需要搞一个GUI程序显示地图上所有人的移动。设计的方案是将整个地图缩小到只有一屏,把用户显示为一个红点,可以动态的增加用户,还可以实时显示服务器当前各个区域的负载图。除了这个需求外,以前也碰到过一些需要GUI工具的需求,如检查任务定义的excel,检查地图配置的xml的有效性等。这些目前都是通过Web或Flash帮忙做了,但其实这些工具最好是后台程序员维护,毕竟一些限制、检查后台开发是最清楚的。
于是乎N年来第一次这么想写GUI程序,哥不搞则以,一搞惊人哈哈!即整就整一个通用点的吧!!整理需求如下:
- 常用的工具程序一般要经常修改,So GUI工具程序一定要用脚本写
- 使用工具的人大致为开发、策划、运维,知道她们都用神马系统吗?普通青年用window,文艺青年用Mac,二逼青年用Linux,So Gui工具还要跨平台
- 世界上最容易编写的GUI是神马?我的答案是HTML,大学里尽JB写web了,要是能让哥能用HTML+JQuery,那效率绝对是杠杆的。但是如果直接写Php页面有一些缺陷,一是他不能长期运行,点一下运行一下,二是普通Html+Jquery是不能访问本地文件系统的,更不能自己发起socket连接到服务器。
经过一二两条,剩下的就是Lua和python了,但是Lua库太少,果断排除。加上第三条,经过艰苦的google加demo测试剩下python +widget、 和 python + Qt。刚开始苦逼的选择了wxpython,普通HTML页面鼓捣几个小时就搞出来了,这时才悲剧的发现塔不支持CSS 和 Javascript,连表单都不支持,我自己给其扩展了一下好不容易支持按钮了,但是不支持javascript太让我不甘心了。So 果断丢弃代码。
最后PyQt成为我最后的选择,稍微看了一下Qt库,就不禁感叹,这库太JB牛逼了,外国佬揍是牛逼,这么牛逼的库开源出来。Qt中包含了N多方面的封装,其中Webkit就是专门用来渲染HTML的,Chrome、Safari等都是基于webkit引擎渲染,怪不人家能有这么帅的浏览器,人家基础库搞的好,长期技术积累啊。咋没见国人搞神马渲染引擎。这真是造福人类的好东东。我一直认为最牛逼的软件就是QT、Webkit这样的,开发此软件的人牛逼,连使用这些软件的人都觉的能够使用这样牛逼的软件,觉得自己也牛逼。除qt,webkit外,还有mysql、Linux、memcache、gcc 。我见过N过精通Oracle的人牛逼哄哄的样子,Oracle的作者我没见过,应该是更牛逼哄哄吧。
下面详述一下我的实现:主要基于window平台(注:目前是个普通青年)
1. 安装python
window 下载安装包,一路下一步即可,下载地址python.org,推荐下载python2.7 32位版本,推荐连接
python-2.7.1.zip
linux:yum/apt 一键安装
2. 安装pyqt4
win下下载相应的安装包,注意和python版本对应,推荐下载
PyQt-Py2.7-x86-gpl-4.9-1.exe | Windows 32 bit installer |
http://www.riverbankcomputing.co.uk/software/pyqt/download
linux yum/apt 或者下载tar包自己安装,二逼青年总是会麻烦一点。
3. 下载偶的示例代码:
svn co https://ffown.googlecode.com/svn/trunk/python
4. 运行
双击main.py即可运行,运行效果图如下,主要包括通过google下载图片的例子、jquery控制按钮例子,javascript通过python访问文件系统例子,url重定向例子,还有一个html5动画的例子。
5. 框架详解:
要用pyqt实现一个浏览器,最少只需如下几行代码:参见pylib/simple.py
import sys
from PyQt4.QtCore import *
from PyQt4.QtGui import *
from PyQt4.QtWebKit import *
app = QApplication(sys.argv)
web = QWebView()
web.load(QUrl("http://www.cnblogs.com/zhiranok"))
web.show()
sys.exit(app.exec_())
我自己将PyQtWebkit封装到pylib下的ffqt.py
和上面不同的是1我封装了几个函数供Javascript调用。2我默认调用html目录下的index.html文本即可,若要修改GUI只需修改index.html文件即可。
class PythonJS(QObject):url = []__pyqtSignals__ = ("contentChanged(const QString &)")@pyqtSignature("", result="QString")def get_image_url(self):if len(self.url) == 0:search_url = 'http://ffown.sinaapp.com/get_image_url.php'search_ret = eval(urllib.urlopen(search_url).read())self.url = search_retdest = self.url[random.randint(0, 100) % len(self.url)]return dest@pyqtSignature("QString", result="QString")def readfile(self, path):ret = ""try:f = open(path, "r")ret = f.read()f.close()except:ret = "file not exist!" + pathtraceback.print_exc()return ret@pyqtSignature("QString", result="QString")def select_file(self, ext = "*"):ret = QFileDialog.getOpenFileName(None, "", ext, "FileDialog")return re
这里PythonJS就是为javascript封装的扩展函数库,每个成员方法javascript都可以直接调用,如读取文件内容的readfile在javascript中调用方式为
python.readfile(file_path)
这样javascript不方便做的如访问文件系统、socket连接、数据库访问等,都可以交个python来做。利用HTML加Jquery很容易写出一个很实用的GUI程序。
please Try it,欢迎文艺青年、二逼青年、普通青年测试、报bug。
Base PyQt4, Simple Web APP Framwork相关推荐
- How to setup SLF4J and LOGBack in a web app - fast--转载
原文:https://wiki.base22.com/display/btg/How+to+setup+SLF4J+and+LOGBack+in+a+web+app+-+fast Logback is ...
- 如何使用Next.js创建动态的Rick and Morty Wiki Web App
Building web apps with dynamic APIs and server side rendering are a way to give people a great exper ...
- .net core 源码解析-web app是如何启动并接收处理请求(二) kestrel的启动
上篇讲到.net core web app是如何启动并接受请求的,下面接着探索kestrel server是如何完成此任务的. 1.kestrel server的入口KestrelServer.Sta ...
- Dockerizing a Node.js web app
2019独角兽企业重金招聘Python工程师标准>>> Dockerizing a Node.js web app The goal of this example is to sh ...
- 为 Python Web App 编写 Dockerfiles
原文地址:How to write Dockerfiles for Python Web Apps 原文作者:Praveen Durairaj 译文出自:掘金翻译计划 本文永久链接:github.co ...
- 使用 jQuery Mobile 与 HTML5 开发 Web App (十四) —— jQuery Mobile 方法下
本文承接上文<使用 jQuery Mobile 与 HTML5 开发 Web App -- jQuery Mobile 方法上>,继续说明 jQuery Mobile 的方法,这部分内容主 ...
- 使用 jQuery Mobile 与 HTML5 开发 Web App (九) —— jQuery Mobile 页面与对话框
在<使用 jQuery Mobile 与 HTML5 开发 Web App -- jQuery Mobile 基础>中,Kayo 曾经简略介绍过 jQuery Mobile 的页面组件,当 ...
- 渐进式app_如何编写渐进式Web App新闻网站
渐进式app For the last two weeks, I worked on a personal project called The Global Upvote. The Global U ...
- 基于Web+App的快递公司物流管理信息系统设计与实现
摘 要:随着互联网的技术的快速发展和无线网络的更新迭代,使4G网络已成为过去式5G网络蓬勃发展.技术的发展,硬件的提高使人们使用智能手机可以更加快速.便捷的浏览信息.获取信息.本文首先介绍快递公司物流 ...
最新文章
- 中科院冯洋| Prefix-to-Prefix生成:进展、挑战与展望
- PHP的内存泄露问题与垃圾回收
- DevOps Troubleshooting(1)-运维思想
- delphi SAP
- 正确的WordPress文件权限[关闭]
- HDUOJ 1062 TEXT REVERSE
- Alibaba Cloud Toolkit 中SLS插件助力线上服务问题排查
- ElementUI的el-table隐藏id列
- html jade文件,Jade模板
- dataframe中多列除以不同列_Python之DataFrame切片与索引实验
- linux系统安全检查
- Ubuntu的常识使用了解2
- 为什么这本搜索引擎营销的书畅销呢?
- 开源文档管理系统mysql_14款开源文档管理系统
- 刨根究底字符编码之九——字符编码方案的演变与字节序
- 基于图神经网络的图像分类,遥感图像分析
- MapBoxMap 之 定位
- 一章——Web网站服务(一)(应用—linux高级管理)
- 《MATLAB SYNTAX》第1章 数据类型
- 欢迎光临Simon个人空间