相机校准前需要设置wifi的mac地址和切换校准模式,之前写的命令行工具,去了工厂发现使用可能有障碍,就做了个小应用程序,用了两种方法,先看一下第一种(不想选择的)
使用Tkinter做图形界面
Tkinter写界面麻烦,文档资料也不是很多,这里只做代码展示
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
#!/usr/bin/python # -*- coding: UTF-8 -*- from Tkinter import * # 导入 Tkinter 库 from tkMessageBox import * import httplib import re class MainWindow: def __init__( self ): root = Tk() root.title( "工具" ) width = 500 height = 300 screenwidth = root.winfo_screenheight() screenheight = root.winfo_screenheight() size = '%dx%d+%d+%d' % (width, height, (screenwidth - width) / 2 , (screenheight - height) / 2 ) root.geometry(size) root.minsize(width, height) root.maxsize(width, height) Label(root, height = 4 , width = 14 , text = "扫描数据:" ).grid(row = 0 , column = 0 , sticky = W) self .name = StringVar() Entry(root, width = 30 , textvariable = self .name).grid(row = 0 , column = 1 , columnspan = 2 ) b1 = Button(root, text = "发送MAC数据" , height = 4 , width = 10 , command = self .send) b1.grid(row = 2 , column = 0 , sticky = E) b2 = Button(root, text = "切换校准模式" , height = 4 , width = 10 , command = self .close) b2.grid(row = 2 , column = 1 , sticky = E) b3 = Button(root, text = "清空" , height = 4 , width = 10 , command = self .clear) b3.grid(row = 2 , column = 2 , sticky = E) root.mainloop() def send( self ): if self .name.get() = = '': showwarning( "输入为空" , "参数不能为空,请重新操作!" ) else : result = re.sub(r "(?<=\w)(?=(?:\w\w)+$)" , " " , self .name.get()) self .httpSend(result) def close( self ): self .httpDisconnect() def clear( self ): self .name. set ('') # 创建HTTP连接 def httpSend( self , mac): httpClient = None # 进行操作 # 创建HTTP连接 def httpDisconnect( self ): httpClient = None # 进行操作 if __name__ = = '__main__' : MainWindow() |
使用PyQt4做图形界面
大学时候自学过一点Qt4.8.4的东西,所以比较倾向于用pyqt开发,跨平台,而且资料也比较齐全,特别是Qt脱离诺基亚后这几年发展迅猛,很多公司都开始采用Qt来开发图形界面应用了
首先配置环境
sudo apt-get install python-pip python2.7-dev libqt4-dev libqt4-dbg libqt4-gui libqt4-sql qt4-dev-tools qt4-doc qt4-designer qt4-qtconfig pyqt4-dev-tools
然后看代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
|
#!/usr/bin/python # -*- coding: utf-8 -*- import sys import httplib import re from PyQt4.QtCore import * from PyQt4.QtGui import * #这里为了偷懒,用到啥导入啥 class MainWindow(QWidget): def __init__( self ,parent = None ): QWidget.__init__( self ,parent) self .setWindowTitle(u '工具' ) mac = QLabel(u '扫描数据:' ) self .macEdit = QLineEdit() grid = QGridLayout() grid.addWidget(mac, 1 , 0 ) grid.addWidget( self .macEdit, 1 , 1 ) clear = QPushButton(u '清空' ) send = QPushButton(u '发送' ) disconnect = QPushButton(u '断开' ) grid.addWidget(clear, 2 , 1 ) grid.addWidget(send, 3 , 1 ) grid.addWidget(disconnect, 4 , 1 ) self .setLayout(grid) self .resize( 550 , 200 ) screen = QDesktopWidget().screenGeometry() size = self .geometry() self .move((screen.width() - size.width()) / 2 ,(screen.height() - size.height()) / 2 ) self .connect(clear, SIGNAL( 'clicked()' ), self .clearAction) self .connect(send, SIGNAL( 'clicked()' ), self .sendAction) self .connect(disconnect, SIGNAL( 'clicked()' ), self .httpDisconnect) def clearAction( self ): self .macEdit.clear() def sendAction( self ): macText = self .macEdit.text() if macText = = '': msgBox = QMessageBox(QMessageBox.Warning,u '输入为空' ,u '参数不能为空,请重新操作!' ) msgBox.exec_() else : result = re.sub(r "(?<=\w)(?=(?:\w\w)+$)" , " " , unicode (macText)) # print(u'mac地址为:%s' % result) self .httpSend(result) # 创建HTTP连接 def httpSend(window,mac): httpClient = None try : response = httpClient.getresponse() if response.status = = 200 and response.reason = = 'OK' : msgBox = QMessageBox(QMessageBox.Information,u '设置成功' ,u '相机MAC地址设置成功,请等待相机重新启动!' ) msgBox.exec_() except Exception, e: # print e msgBox = QMessageBox(QMessageBox.Warning,u '操作失败' ,u '操作失败,请重新操作!' ) msgBox.exec_() finally : if httpClient: httpClient.close() # 创建HTTP连接 def httpDisconnect(window): httpClient = None try : response = httpClient.getresponse() if response.status = = 200 and response.reason = = 'OK' : msgBox = QMessageBox(QMessageBox.Information,u '断开成功' ,u '现在相机已经进入校准模式,可以进行校准!' ) msgBox.exec_() except Exception, e: # print e msgBox = QMessageBox(QMessageBox.Warning,u '操作失败' ,u '操作失败,请重新操作!' ) msgBox.exec_() finally : if httpClient: httpClient.close() #main if __name__: app = QApplication(sys.argv) window = MainWindow() window.show() sys.exit(app.exec_()) |
安装打包程序
pip install pyinstaller
也可以源码安装,下载源码包,然后进入包目录,执行下面的命令(需要安装setuptools):
python setup.py install
安装完后,检查安装成功与否:
pyinstaller --version
安装成功后,就可以使用下面的命令了:
pyinstaller : 打包可执行文件的主要命令,详细用法下面会介绍。
pyi-archive_viewer : 查看可执行包里面的文件列表。
pyi-bindepend : 查看可执行文件依赖的动态库(.so或.dll文件)
pyi-… : 等等。
pyinstaller的语法:
pyinstaller [options] script [script ...] | specfile
最简单的用法,在和myscript.py同目录下执行命令:
pyinstaller pyqt.py
然后会看到新增加了两个目录build和dist,dist下面的文件就是可以发布的可执行文件,对于上面的命令你会发现dist目录下面有一堆文 件,各种都动态库文件和myscrip可执行文件。有时这样感觉比较麻烦,需要打包dist下面的所有东西才能发布,万一丢掉一个动态库就无法运行了,好 在pyInstaller支持单文件模式,只需要执行:
pyinstaller -F pyqt.py
你会发现dist下面只有一个可执行文件,这个单文件就可以发布了,可以运行在你正在使用的操作系统类似的系统的下面。
当然,pyinstaller还有各种选项,有通用选项,如-d选项用于debug,了解pyInstaller执行的过程;还有一些针对不同平台的选项,具体用法可以访问PyInstaller官方WIKI。
PyInstaller的原理简介
PyInstaller其实就是把python解析器和你自己的脚本打包成一个可执行的文件,和编译成真正的机器码完全是两回事,所以千万不要指望 成打包成一个可执行文件会提高运行效率,相反可能会降低运行效率,好处就是在运行者的机器上不用安装python和你的脚本依赖的库。在Linux操作系 统下,它主要用的binutil工具包里面的ldd和objdump命令。
PyInstaller输入你指定的的脚本,首先分析脚本所依赖的其他脚本,然后去查找,复制,把所有相关的脚本收集起来,包括Python解析器,然后把这些文件放在一个目录下,或者打包进一个可执行文件里面。
可以直接发布输出的整个文件夹里面的文件,或者生成的可执行文件。你只需要告诉用户,你的应用App是自我包含的,不需要安装其他包,或某个版本的Python,就可以直接运行了。
需要注意的是,PyInstaller打包的执行文件,只能在和打包机器系统同样的环境下。也就是说,不具备可移植性,若需要在不同系统上运行,就必须针对该平台进行打包。
来看一下最后的界面
原文链接:https://blog.duicode.com/2660.html