您的位置:首页 > 编程语言 > Python开发

Python学习,给自己的代码做个合集,定制自己的桌面软件!

2018-07-10 21:58 411 查看


在学习Python的过程中,经常会写很多的练手的脚本,那么有没有想过,写到一起呢?当然了,方法有很多,比如写到web网页中,做各种跳转、写到微信中,各种回复关键字调用,还有今天和大家分享的GUI图形用户界面!

构建基本框架

Python中有标准库tkinter,不需要安装即可使用!可以用来写简单的GUI程序,只需要短短几行代码就可以了,比如下面这个:



具体教程大家可以去自行搜索,这里就不一一细说了,注释也写的很清楚!

将自己的其他脚本都写到GUI程序中

其实可以导入其他脚本中的函数,来达到多个脚本整合的效果,但是那样又不是很方便,就先放到一起了,慢慢在完善!

首先是将之前的天气预报写入(这里有个城市代码的字典省略了,很长,大家可以去我相关的文章中查找)

def weather():
'''	天气预报查询	'''
global city_code_list#城市列表
city = entry.get()#获取输入的城市名
if city in city_code_list:
city_code = city_code_list[city]
home_page = 'http://www.weather.com.cn'
url = home_page + '/weather/' + city_code + '.shtml'
header = {'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:57.0) Gecko/20100101 Firefox/57.0'}
res = requests.get(url, headers=header)
res.encoding = 'utf-8'
html = etree.HTML(res.text)
for i in range(1, 8):
date = html.xpath('//ul[@class="t clearfix"]/li[{}]/h1/text()'.format(i))[0]
weather = html.xpath('//ul[@class="t clearfix"]/li[{}]/p[1]/text()'.format(i))[0]
tem1 = html.xpath('//ul[@class="t clearfix"]/li[{}]/p[@class="tem"]/span/text()'.format(i))
tem2 = html.xpath('//ul[@class="t clearfix"]/li[{}]/p[@class="tem"]/i/text()'.format(i))
tem = "".join(tem1) + '/' + "".join(tem2)
win1 = html.xpath('//ul[@class="t clearfix"]/li[{}]/p[@class="win"]/i/text()'.format(i))
win2 = html.xpath('//ul[@class="t clearfix"]/li[{}]/p[@class="win"]/em/span[1]/@title'.format(i))
win = "".join(win1) + "".join(win2)
text.insert(END,'%s天气预报查询'%city)#添加数据
text.insert(END,'%s %s %s %s'%(date, weather, tem, win))#添加数据
text.see(END)#文本框向下滚动
text.update()#更新
else:
text.insert(END, '输错了吧?')  # 添加数据
text.see(END)  # 文本框向下滚动
text.update()  # 更新

然后是空气质量排名

def ranking():
city = entry.get()
url = 'http://www.tianqihoubao.com/aqi/aqi_rank.html'
html = requests.get(url)
datas = etree.HTML(html.text).xpath('//table[@class="b"]')[0]
i = 1
for data in datas:
trs = data.xpath('./td')
info = []
for tr in trs:
a = tr.xpath('string(.)').split()[0]
if i % 6 != 0:
info.append(a)
elif i == 6:
text.insert(END, '%s' % (" | ".join(info))) # 第一行
elif city in info:#判断需要数据所在行
text.insert(END, '%s' % ("   |   ".join(info)))  # 添加需要的数据
text.see(END)  # 文本框向下滚动
text.update()  # 更新
info = []
i += 1

最后是空气指数查询

def quality():
url = 'http://www.tianqihoubao.com/aqi/'
html = requests.get(url)
html.encoding = 'gbk'
citys = etree.HTML(html.text).xpath('//div[@class="citychk"]/dl/dd/a/text()')
city_urls = etree.HTML(html.text).xpath('//div[@class="citychk"]/dl/dd/a/@href')
dic = {}#构架城市列表
for city, city_url in zip(citys, city_urls):
city = city.replace(" ", "")
city_url = 'http://www.tianqihoubao.com/' + city_url
dic[city] = city_url
city_n = entry.get()
if city_n in dic.keys():
html_n = requests.get(dic[city_n])
html_n.encoding = 'gbk'
data = etree.HTML(html_n.text)
num = data.xpath('//div[@class="num"]/text()')[0].strip()
status = data.xpath('//div[@class="status"]/text()')[0].strip()
explain = data.xpath('//div[@class="hd"]/div[@id="content"]/div[@class="txt01"]/h4')[0].xpath('string(.)')
surveys = re.findall(r'<td.*?>(.*?)</td>', html_n.text, re.S)
sur = re.sub("</b>", "|", ''.join([x.strip().replace("<b>", ' ') for x in surveys[0:9]]))[:-1]
sur2 = [x.strip().replace(" ", '') + '|' for x in surveys[9:]]
surv = [sur2[i:i + 9] for i in range(0, len(sur2), 9)]
text.insert(END,'%s空气质量查询' % city_n)  # 添加数据
text.insert(END,"%s空气质量指数: %s" % (city_n, num))  # 添加数据
text.insert(END,"%s空气质量:    %s" %(city_n, status))  # 添加数据
text.insert(END,explain)  # 添加数据
text.insert(END,sur)  # 添加数据
for su in surv:
text.insert(END," ".join(su)[:-1])  # 添加数据
text.see(END)  # 文本框向下滚动
text.update()  # 更新
else:
text.insert(END, '输错了吧?')  # 添加数据
text.see(END)  # 文本框向下滚动
text.update()  # 更新

好了,现在是主函数

if __name__ == '__main__':
root = Tk()
root.title("我的应用汇总")#窗口标题
root.geometry('660x600+600+50')#窗口大小位置 用x链接 +后面是位置
label = Label(root,text="<<-----云飞学编程----Q群542110741----->>",font=('微软雅黑'))#创建标签控件
label.grid(row=0,columnspan=3)#网格式布局
text = Listbox(root,font=('微软雅黑',15),width=55,height=18)#列表框控件,设置组件默认宽高
text.grid(row=2,columnspan=4)#columnspan为组件所跨越的列数
button_tq = Button(root,text="天气预报查询",font=('微软雅黑',8),command=weather)#点击按钮
button_tq.grid(row=1,column=1)
button_kq = Button(root,text="空气质量查询",font=('微软雅黑',8),command=quality)#点击按钮
button_kq.grid(row=1,column=3)
button_pm = Button(root,text="空气质量排名",font=('微软雅黑',8),command=ranking)#点击按钮
button_pm.grid(row=1,column=2)
entry = Entry(root,font=('微软雅黑'))#创建输入框
entry.grid(row=1,column=0)#定位第1行3列
root.mainloop()

运行效果如下:



上面3个爬虫,都在以往的文章中发过,大家如果感兴趣可以去看看!这里就不详细注释了,只是复制过来稍微修改下就用了!



待改进:

1、内容添加,目前就3个爬虫的内容,慢慢添加更多的感兴趣的内容进去,最终形成自己的定制软件

2、界面的优化,比如滑动条、字体大小、按钮大小位置等等

3、连接数据库,目前的内容都是实时抓取网页内容,连接数据库会更加的快捷

目前就这么多,想到在继续吧!刚开始学习GUI,总有不足之处,如果有更好的建议大家可以评论区讨论哦!需要源码的话就私信我吧!

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  Python Tkinter