用python数据分析excel多地天气_Python实现天气查询功能(外加Excel技巧)

昨天在网上发现了一个非常方便的天气API,就用Python试着用了一下。参数是挺少的,用起来也方便,但是那个城市代码确实是搞了我好长时间。

一、介绍

我们先来看一下实现的程序有什么功能:

功能也是非常简单的,输入城市,显示当前城市、当前日期时间、温度和天气。

API使用的是国家气象局的接口,完全免费的:

这个是以北京为例的接口,其中最后的数字101010100就是北京的城市代码。查询其它城市只需要把城市代码修改成其它城市的就可以了。

因为这个API的访问只能通过城市代码,在这方面还是有点麻烦的,不过我把城市代码整理出了一个json文件,稍后会为大家讲解这个过程。

二、返回数据

这里以南昌为例,因为返回的数据比较多,就不完整的列举了。请求成功时,大致数据如下:

里面还有很多没有拉开的地方,然后我们尝试访问一个错误的城市代码:

其中1是非法的城市代码,我们看一下数据:

{

"message": "Request resource not found.",

"status": 404

}

两者都有一个status,也就是状态码。当状态码为200时,说明请求正常完成。404就是我们经常看见的,意思就是没找到。

三、代码讲解

代码是非常简单的,主要就是使用了两个模块:requests、json。一个网络请求,一个json解析。

import requests, json

#api地址

url = 'http://t.weather.sojson.com/api/weather/city/'

#输入城市中文

city = input("请输入你要查询的城市:")

#读取json文件

f = open('city.json', 'rb')

#使用json模块的load方法加载json数据,返回一个字典

cities = json.load(f)

#通过城市的中文获取城市代码

city = cities.get(city)

#网络请求,传入请求api+城市代码

response = requests.get(url + city)

#将数据以json形式返回,这个d就是返回的json数据

d = response.json()

#当返回状态码为200,输出天气状况

if(d['status'] == 200):

print("城市:", d["cityInfo"]["parent"], d["cityInfo"]["city"])

print("时间:", d["time"], d["data"]["forecast"][0]["week"])

print("温度:", d["data"]["forecast"][0]["high"], d["data"]["forecast"][0]["low

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值