长时间以来,一直针对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相关推荐

  1. 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 ...

  2. 如何使用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 ...

  3. .net core 源码解析-web app是如何启动并接收处理请求(二) kestrel的启动

    上篇讲到.net core web app是如何启动并接受请求的,下面接着探索kestrel server是如何完成此任务的. 1.kestrel server的入口KestrelServer.Sta ...

  4. Dockerizing a Node.js web app

    2019独角兽企业重金招聘Python工程师标准>>> Dockerizing a Node.js web app The goal of this example is to sh ...

  5. 为 Python Web App 编写 Dockerfiles

    原文地址:How to write Dockerfiles for Python Web Apps 原文作者:Praveen Durairaj 译文出自:掘金翻译计划 本文永久链接:github.co ...

  6. 使用 jQuery Mobile 与 HTML5 开发 Web App (十四) —— jQuery Mobile 方法下

    本文承接上文<使用 jQuery Mobile 与 HTML5 开发 Web App -- jQuery Mobile 方法上>,继续说明 jQuery Mobile 的方法,这部分内容主 ...

  7. 使用 jQuery Mobile 与 HTML5 开发 Web App (九) —— jQuery Mobile 页面与对话框

    在<使用 jQuery Mobile 与 HTML5 开发 Web App -- jQuery Mobile 基础>中,Kayo 曾经简略介绍过 jQuery Mobile 的页面组件,当 ...

  8. 渐进式app_如何编写渐进式Web App新闻网站

    渐进式app For the last two weeks, I worked on a personal project called The Global Upvote. The Global U ...

  9. 基于Web+App的快递公司物流管理信息系统设计与实现

    摘 要:随着互联网的技术的快速发展和无线网络的更新迭代,使4G网络已成为过去式5G网络蓬勃发展.技术的发展,硬件的提高使人们使用智能手机可以更加快速.便捷的浏览信息.获取信息.本文首先介绍快递公司物流 ...

最新文章

  1. 中科院冯洋| Prefix-to-Prefix生成:进展、挑战与展望
  2. PHP的内存泄露问题与垃圾回收
  3. DevOps Troubleshooting(1)-运维思想
  4. delphi SAP
  5. 正确的WordPress文件权限[关闭]
  6. HDUOJ 1062 TEXT REVERSE
  7. Alibaba Cloud Toolkit 中SLS插件助力线上服务问题排查
  8. ElementUI的el-table隐藏id列
  9. html jade文件,Jade模板
  10. dataframe中多列除以不同列_Python之DataFrame切片与索引实验
  11. linux系统安全检查
  12. Ubuntu的常识使用了解2
  13. 为什么这本搜索引擎营销的书畅销呢?
  14. 开源文档管理系统mysql_14款开源文档管理系统
  15. 刨根究底字符编码之九——字符编码方案的演变与字节序
  16. 基于图神经网络的图像分类,遥感图像分析
  17. MapBoxMap 之 定位
  18. 一章——Web网站服务(一)(应用—linux高级管理)
  19. 《MATLAB SYNTAX》第1章 数据类型
  20. 欢迎光临Simon个人空间

热门文章

  1. 选择 GCD 还是 NSTimer ?
  2. 《Redis官方文档》Redis调试指南
  3. C/C++ 读取16进制文件
  4. javascript与xml实例应用
  5. Oracle interview
  6. sqlite3源码编译到Android,实现SQLite跨全平台使用
  7. Oracle 11G 安装详解
  8. display: inline-block 布局
  9. 68.iOS设备尺寸及型号代码(iPhoneXR/XS)
  10. 子元素相对于父元素垂直居中对齐