Python实战之制作天气查询软件

作者:借我一生执拗 时间:2022-09-21 09:00:20 

前言

本文主要给大家介绍的是关于Python制作天气查询软件,下面话不多说了,来一起看看详细的介绍吧

效果图

Python实战之制作天气查询软件

以前,给大家分享了如何使用 PyQt5 制作猜数游戏和计时器,这一次,我们继续学习:如何使用 PyQt5 制作天气查询软件。

源代码和 exe 文件:

github 地址:https://github.com/xflywind/Python-Application

本地下载:http://xiazai.jb51.net/201905/yuanma/weather-python(jb51.net).rar

开发环境

  • Python3

  • PyQt5

  • requests

准备工作

首先要获取不同城市对应的天气代码,可以从https://www.heweather.com/documents/city.html 网站下载 csv 文件(文末获取 csv 文件),拿到 csv 文件,我们首先要进行数据预处理工作。


import pandas as pd
# 将下载好的文件命名为 'city_code.csv',并删除 header
file = pd.read_csv('city_code.csv')
# 选取需要的两列信息
file = file.loc[:,['City_ID', 'City_CN']]
# 读取前五行信息
file.head()

Python实战之制作天气查询软件


# 匹配 City_ID 中的数字
def convert(x):
pat = re.compile('(\d+)')
return pat.search(x).group()

file['City_ID_map'] = file['City_ID'].map(convert)

# 建立城市与代码之间的映射关系
def city2id(file):
code_dict = {}
key = 'City_CN'
value = 'City_ID_map'
for k, v in zip(file[key], file[value]):
code_dict[k] = v
return code_dict
code_dict = city2id(file)

# 将所得的字典数据存储为 txt 文件
import json
filename = 'city_code.txt'
with open(filename, 'w') as f:
json.dump(code_dict, f)

将字典存储为 txt 文件后,以后我们只需读取文件,再获取字典:


with open(filename, 'r') as f:
text = json.load(f)

如果不想费工夫处理这些数据,可以直接使用文末提供的 city_code.txt 文件。

Ui 设计

使用 Qt Designer,我们不难设计出以下界面:

Python实战之制作天气查询软件

如果不想设计这些界面,可以直接导入我提供的 Ui_weather.py 文件。

主体逻辑:

我们这次使用的 api 接口为:'http://wthrcdn.etouch.cn/weather_mini?citykey=[code]',code 就是之前处理过的城市代码,比如常州的城市代码为:101191101。替换掉变量 code ,网站返回给我们一段 json 格式的文件:

Python实战之制作天气查询软件

根据这段 json 语句,我们很容易提取需要的信息:


# 天气情况
data = info_json['data']
city = f"城市:{data['city']}\n"
today = data['forecast'][0]
date = f"日期:{today['date']}\n"
now = f"实时温度:{data['wendu']}度\n"
temperature = f"温度:{today['high']} {today['low']}\n"
fengxiang = f"风向:{today['fengxiang']}\n"
type = f"天气:{today['type']}\n"
tips = f"贴士:{data['ganmao']}\n"

当然,我们首先要使用 requests,get 方法,来获取这段 json 代码。


def query_weather(code):
# 模板网页
html = f'http://wthrcdn.etouch.cn/weather_mini?citykey=[code]'

# 向网页发起请求
try:
info = requests.get(html)
info.encoding = 'utf-8'
# 捕获 ConnectinError 异常
except requests.ConnectionError:
raise

# 将获取的数据转换为 json 格式
try:
info_json = info.json()
# 转换失败提示无法查询
except JSONDecodeError:
return '无法查询'

下面我们介绍下本文用到的控件方法:


# 将 textEdit 设置为只读模式
self.textEdit.setReadOnly(True)
# 将鼠标焦点放在 lineEdit 编辑栏里
self.lineEdit.setFocus()
# 获取 lineEdit 中的文本
city = self.lineEdit.text()
# 设置文本
self.textEdit.setText(info)
# 清空文本
self.lineEdit.clear()

为查询按钮设置快捷键:


def keyPressEvent(self, e):
# 设置快捷键
if e.key() == Qt.Key_Return:
self.queryWeather()

最后,我们可以使用 Pyinstaller -w weather.py 打包应用程序,但是要记得打包完,将 city_code.txt 复制到 dist/weather 文件夹下,否则程序无法运行。

以上便是本文的全部内容了,更详细的内容请见源代码。

源代码和 exe 文件:

github 地址:https://github.com/xflywind/Python-Application

本地下载:http://xiazai.jb51.net/201905/yuanma/weather-python(jb51.net).rar

来源:https://www.jianshu.com/p/23bbc48956b9

标签:python,天气,查询
0
投稿

猜你喜欢

  • MySQL数据库中varchar类型的数字比较大小的方法

    2024-01-14 17:10:35
  • 教你如何编写Vue.js的单元测试的方法

    2024-04-26 17:38:09
  • JSON.parse处理非标准Json数据出错的解决

    2024-04-18 09:49:12
  • 详解JS深拷贝与浅拷贝

    2024-05-22 10:40:40
  • asp如何最准确地统计在线用户数?

    2010-07-11 21:12:00
  • 解决Windows环境下安装 mysql-8.0.11-winx64 遇到的问题

    2024-01-22 18:45:21
  • ASP中取得图片宽度和高度

    2009-11-08 18:39:00
  • Pycharm生成可执行文件.exe的实现方法

    2023-07-19 12:09:54
  • python如何寻找主串中所有指定子串下标

    2023-11-27 08:38:41
  • openCV入门学习基础教程第三篇

    2022-05-20 00:00:59
  • MySQL 导出数据为csv格式的方法

    2024-01-26 04:52:57
  • Python实现自定义读写分离代码实例

    2023-04-19 14:34:57
  • Matplotlib绘制条形图的方法你知道吗

    2022-12-05 15:23:59
  • 各个版本IE合集下载,共存无冲突

    2007-11-29 13:12:00
  • 手机版远程网站文件删除ASP程序

    2009-02-24 16:23:00
  • asp超强的Server Application Error 的解决方法

    2008-11-13 13:04:00
  • 如何将数据库里的记录生成一个Excel文件?

    2009-12-03 20:09:00
  • python文件目录操作之os模块

    2023-01-10 14:22:59
  • 浅谈Django中的数据库模型类-models.py(一对一的关系)

    2024-01-24 18:32:11
  • MySQL组合索引与最左匹配原则详解

    2024-01-24 18:28:16
  • asp之家 网络编程 m.aspxhome.com