使用wxpython开发windows界面

简介: 本文的原文连接是: http://blog.csdn.net/freewebsys/article/details/49930675未经博主允许不得转载。 博主地址是:http://blog.csdn.net/freewebsys1,需求需要给运营童鞋开发一个桌面客户端程序。 不想使用java开发,启动慢,客户端程序大。开发难度大,会SWING的人少。 于是使

本文的原文连接是: http://blog.csdn.net/freewebsys/article/details/49930675未经博主允许不得转载。
博主地址是:http://blog.csdn.net/freewebsys

1,需求

需要给运营童鞋开发一个桌面客户端程序。
不想使用java开发,启动慢,客户端程序大。开发难度大,会SWING的人少。
于是使用wxPython开发,开发调试开发速度非常快。
但是在windows下打包成exe遇到一堆编码问题。
恶心的我都(ˇˍˇ) 想~用java重写。

2,资源下载

python下载:
https://www.python.org/downloads/windows/
wxPython下载:
http://sourceforge.net/projects/wxpython/files/wxPython/
py2exe
http://py2exe.org/
本来都可以使用最新版本的。但是py2exe最高就支持2.7的python所以,这三个软件都永远的停留在了2.7。
同时py2exe还需要一个2008的lib包。
http://www.microsoft.com/en-us/download/details.aspx?id=29

这里的软件都使用32bit的,因为有一个特性是可以将文件合并。其实也用不到64位的特性。

3,python编码问题

这个是个硬伤。java支持编码挺好的。python的中文编码痛苦了。折腾好几天才好。
这里总结下:

3.1,首先是http请求

开始开发的时候使用requests库,但是运行找不到库。
于是全部使用urllib2库,请求http。
一般比较全的demo:
https://pymotw.com/2/urllib2/
参考博客:
http://blog.csdn.net/zbyufei/article/details/5856730

3.2,举一个简单例子


比如做两个按钮的工具,一个显示text文本。
第一个button显示百度首页,第二个button显示搜索内容。当然都是html格式的。
代码如下,然后具体分析:

#!/usr/bin/env python
# encoding: utf-8
import sys
import urllib
import urllib2
import ssl
import wx

charset = "utf-8"
###编写一个按钮,点击拉取 https://m.baidu.com/ 内容,显示到文本里面。
###############重新加载系统的编码。###############
reload(sys)
sys.setdefaultencoding(charset)


# 使用百度进行显示首页和查询。
def get_baidu_html(param):
    url = "https://m.baidu.com/"
    if param == "":
        request = urllib2.Request(url)
    else:
        url = url + "s?word=" + unicode(urllib.quote_plus(param))
        print(url)
        request = urllib2.Request(url)
    request.add_header('User-agent',
                       'Mozilla/5.0 (Macintosh; U; Intel Mac OS X 10_6_2; en-US) AppleWebKit/533.3 (KHTML, like Gecko) Chrome/5.0.354.0 Safari/533.3')
    request.add_header('Accept-Charset', 'utf-8')

    # 增加https 访问方法
    context = ssl._create_unverified_context()
    data = urllib2.urlopen(request, context=context).read()
    # 将数据转换成Unicode编码。
    return unicode(data)


##主窗口。
class MyFrame(wx.Frame):
    def __init__(self):
        wx.Frame.__init__(self, parent=None, id=-1, title=u'Demo工具', size=(600, 400))
        sizer = wx.BoxSizer(wx.VERTICAL)

        # 增加按钮布局
        box = wx.BoxSizer(wx.HORIZONTAL)
        self.btnHome = wx.Button(self, -1, u'首页')
        self.btnSearch = wx.Button(self, -1, u'搜索')

        box.Add(self.btnHome, 1, wx.ALIGN_CENTRE | wx.ALL, 0)
        box.Add(self.btnSearch, 1, wx.ALIGN_CENTRE | wx.ALL, 0)
        sizer.Add(box, 0, wx.GROW | wx.ALIGN_CENTER_VERTICAL | wx.ALL, 1)

        self.textHtml = wx.TextCtrl(self, -1, "", size=(500, 300),
                                    style=wx.TE_MULTILINE | wx.TE_PROCESS_ENTER)
        sizer.Add(self.textHtml, 0, wx.ALIGN_CENTRE | wx.ALL, 5)

        # 增加sizer。
        self.SetSizer(sizer)
        sizer.Fit(self)

        # 绑定事件。
        self.Bind(wx.EVT_BUTTON, self.OnHome, self.btnHome)
        self.Bind(wx.EVT_BUTTON, self.OnSearch, self.btnSearch)

    def OnHome(self, event):
        # 可以获得btn对象。
        btn = event.GetEventObject()
        label = btn.GetLabel()
        print(label)
        html = get_baidu_html("")
        self.textHtml.SetValue(html)

    def OnSearch(self, event):
        btn = event.GetEventObject()
        label = btn.GetLabel()
        print(label)
        html = get_baidu_html("中国")
        self.textHtml.SetValue(html)


if __name__ == '__main__':
    app = wx.App()
    wx.InitAllImageHandlers()
    frame_1 = MyFrame()
    app.SetTopWindow(frame_1)
    frame_1.Show()
    app.MainLoop()

首先这个是一个https的请求,必须使用python3.0的版本。

    # 增加https 访问方法
    context = ssl._create_unverified_context()
    data = urllib2.urlopen(request, context=context).read()

然后整个文件运行都是使用utf-8格式的。在头部重新声明了utf-8

# encoding: utf-8
import sys
charset = "utf-8"
###############重新加载系统的编码。###############
reload(sys)
sys.setdefaultencoding(charset)

声明了文件格式是utf-8,并且重新加载了默认系统的字符,这个很重要因为windows下默认变成了GBK。
在http请求里面也增加了。

    request.add_header('Accept-Charset', 'utf-8')

最后将文件显示到text里面的时候进行转码。

    # 将数据转换成Unicode编码。
    return unicode(data)

一个需要这几个地方转换成utf-8的格式之后才能显示中文,不乱码。
研究了半天才明白。

3.3 ,页面布局绑定事件

使用sizer布局。

# 绑定事件。
        self.Bind(wx.EVT_BUTTON, self.OnHome, self.btnHome)
        self.Bind(wx.EVT_BUTTON, self.OnSearch, self.btnSearch)

注意如果要是有输入参数,再做搜索需要对字符串进行转码。

strXXX.encode("utf-8")

然后再搜索。

4,打包

这个必须说下,使用是virtualbox,虚拟的xp系统。win7也类似。
将上面说的python程序安装好之后。就可以打包了。需要将python设置到环境变量里面。
打包python:

#!/usr/bin/env python
# encoding: utf-8

# python setup_win.py py2exe

from distutils.core import setup
import py2exe

options = {
    "py2exe":
        {"compressed": 1,  # 压缩
         "optimize": 2,
         "ascii": 0,
         "bundle_files": 1  # 所有文件打包成一个exe文件
         }
}
setup(
    options=options,
    console=[{"script": "demo.py"}],
    windows=[{"script": "demo.py"}]
)

这个只有32bit的才能使用bundle_files。将文件打包成一个zip。

虽然打包成了一个library。但是还包括两个exe程序。


文件压缩了下,一共大小是 7MB左右,已经非常小了。很满意。

说明下,打包setup中又两个参数一个是console模式,这个是启动一个cmd程序,同时可以打印出print日志,方便调试。
另外一个是windows模式,这个直接启动界面,给用户用的使用使用这个模式,看着清爽些。

说明,最后咋也没用将icon图标放到exe程序上面。

5,总结

本文的原文连接是: http://blog.csdn.net/freewebsys/article/details/49930675未经博主允许不得转载。
博主地址是:http://blog.csdn.net/freewebsys

python打包成exe,给了我们开发工具的一个很便捷的办法。
开发效率非常高。而且wxPython官方提供了一个非常全面的demo。
直接拷贝上面的例子就能开发复杂的应用了。
windows字符还是非常坑的。但是明白了需要注意的地方之后,
做点有用的小工具还是非常有意思的。能提高不少效率。

目录
相关文章
|
8天前
|
Windows
解决windows下Qt Creator显示界面过大的问题
解决windows下Qt Creator显示界面过大的问题
|
1月前
|
数据可视化 数据库 C++
Qt 5.14.2揭秘高效开发:如何用VS2022快速部署Qt 5.14.2,打造无与伦比的Windows应用
Qt 5.14.2揭秘高效开发:如何用VS2022快速部署Qt 5.14.2,打造无与伦比的Windows应用
|
1月前
|
监控 开发者 Windows
在 Windows 命令提示行界面下测量一个命令执行的总时间
在 Windows 命令提示行界面下测量一个命令执行的总时间
40 0
|
17天前
|
监控 安全 API
7.3 Windows驱动开发:内核监视LoadImage映像回调
在笔者上一篇文章`《内核注册并监控对象回调》`介绍了如何运用`ObRegisterCallbacks`注册`进程与线程`回调,并通过该回调实现了`拦截`指定进行运行的效果,本章`LyShark`将带大家继续探索一个新的回调注册函数,`PsSetLoadImageNotifyRoutine`常用于注册`LoadImage`映像监视,当有模块被系统加载时则可以第一时间获取到加载模块信息,需要注意的是该回调函数内无法进行拦截,如需要拦截则需写入返回指令这部分内容将在下一章进行讲解,本章将主要实现对模块的监视功能。
34 0
7.3 Windows驱动开发:内核监视LoadImage映像回调
|
4月前
|
监控 安全 API
7.2 Windows驱动开发:内核注册并监控对象回调
在笔者上一篇文章`《内核枚举进程与线程ObCall回调》`简单介绍了如何枚举系统中已经存在的`进程与线程`回调,本章`LyShark`将通过对象回调实现对进程线程的`句柄`监控,在内核中提供了`ObRegisterCallbacks`回调,使用这个内核`回调`函数,可注册一个`对象`回调,不过目前该函数`只能`监控进程与线程句柄操作,通过监控进程或线程句柄,可实现保护指定进程线程不被终止的目的。
30 0
7.2 Windows驱动开发:内核注册并监控对象回调
|
4月前
|
监控 安全 API
7.6 Windows驱动开发:内核监控FileObject文件回调
本篇文章与上一篇文章`《内核注册并监控对象回调》`所使用的方式是一样的都是使用`ObRegisterCallbacks`注册回调事件,只不过上一篇博文中`LyShark`将回调结构体`OB_OPERATION_REGISTRATION`中的`ObjectType`填充为了`PsProcessType`和`PsThreadType`格式从而实现监控进程与线程,本章我们需要将该结构填充为`IoFileObjectType`以此来实现对文件的监控,文件过滤驱动不仅仅可以用来监控文件的打开,还可以用它实现对文件的保护,一旦驱动加载则文件是不可被删除和改动的。
29 1
7.6 Windows驱动开发:内核监控FileObject文件回调
|
4月前
|
监控 安全 API
6.9 Windows驱动开发:内核枚举进线程ObCall回调
在笔者上一篇文章`《内核枚举Registry注册表回调》`中我们通过特征码定位实现了对注册表回调的枚举,本篇文章`LyShark`将教大家如何枚举系统中的`ProcessObCall`进程回调以及`ThreadObCall`线程回调,之所以放在一起来讲解是因为这两中回调在枚举是都需要使用通用结构体`_OB_CALLBACK`以及`_OBJECT_TYPE`所以放在一起来讲解最好不过。
44 1
6.9 Windows驱动开发:内核枚举进线程ObCall回调
|
4月前
|
监控 安全 API
6.8 Windows驱动开发:内核枚举Registry注册表回调
在笔者上一篇文章`《内核枚举LoadImage映像回调》`中`LyShark`教大家实现了枚举系统回调中的`LoadImage`通知消息,本章将实现对`Registry`注册表通知消息的枚举,与`LoadImage`消息不同`Registry`消息不需要解密只要找到`CallbackListHead`消息回调链表头并解析为`_CM_NOTIFY_ENTRY`结构即可实现枚举。
50 1
6.8 Windows驱动开发:内核枚举Registry注册表回调
|
4月前
|
存储 API 开发者
6.7 Windows驱动开发:内核枚举LoadImage映像回调
在笔者之前的文章`《内核特征码搜索函数封装》`中我们封装实现了特征码定位功能,本章将继续使用该功能,本次我们需要枚举内核`LoadImage`映像回调,在Win64环境下我们可以设置一个`LoadImage`映像加载通告回调,当有新驱动或者DLL被加载时,回调函数就会被调用从而执行我们自己的回调例程,映像回调也存储在数组里,枚举时从数组中读取值之后,需要进行位运算解密得到地址。
32 1
6.7 Windows驱动开发:内核枚举LoadImage映像回调
|
4月前
|
监控 安全 API
7.5 Windows驱动开发:监控Register注册表回调
在笔者前一篇文章`《内核枚举Registry注册表回调》`中实现了对注册表的枚举,本章将实现对注册表的监控,不同于32位系统在64位系统中,微软为我们提供了两个针对注册表的专用内核监控函数,通过这两个函数可以在不劫持内核API的前提下实现对注册表增加,删除,创建等事件的有效监控,注册表监视通常会通过`CmRegisterCallback`创建监控事件并传入自己的回调函数,与该创建对应的是`CmUnRegisterCallback`当注册表监控结束后可用于注销回调。
45 0
7.5 Windows驱动开发:监控Register注册表回调