先看下效果图:
用到的模块:
- PyMySQL
- requests
- threading
- wxpy
要实现上面的示例,首先是有两大块地方
- 获取天气信息
- 通过微信将天气信息发送出去
而获取天气信息又包括几个小的需要注意的地方
获取天气信息
- 获取天气信息的接口
- 获取天气信息的城市
- 获取所在城市的城市码
假如我们给多个人发送天气情况,这几个人来自不同的城市,那么我们不可能每次都要输入城市名,然后查找城市码,然后再访问接口,获取天气情况,这样会非常的麻烦,所以我们需要考虑将城市名跟城市码一一对应起来,说到一一对应,首先想到的数据结构便是字典,所以我们可以将这些信息存入一个字典里,然后持久化到一个文件中,这样便方便很多
首先我们获取最新的 city 表,这个表是一个 list 类型,大体格式如下:
[ { "id": 1, "pid": 0, "city_code": "101010100", "city_name": "北京", "post_code": "100000", "area_code": "010", "ctime": "2019-07-11 17:30:06" }, { "id": 2, "pid": 0, "city_code": "", "city_name": "安徽", "post_code": null, "area_code": null, "ctime": null } ]
我们就简单的粘贴复制,放到一个空的列表中,如下所示,将所有的城市信息放到列表 citycode 中
citycode = [ { "id": 1, "pid": 0, "city_code": "101010100", "city_name": "北京", "post_code": "100000", "area_code": "010", "ctime": "2019-07-11 17:30:06" }, ... ... ... ... ... ... { "id": 2, "pid": 0, "city_code": "None", "city_name": "安徽", "post_code": "null", "area_code": "null", "ctime": "null" } ] cityinfo = {} #将城市名和城市代码写入json文件中 with open('city_for_code.json','w',encoding='utf-8') as f: for i in citycode: name = i["city_name"] code = i["city_code"] cityinfo[name] = code f.write(str(cityinfo)) #测试是否能读取 with open('city_for_code.json','r+',encoding='utf-8') as file: data_dst = file.readlines() d = eval(data_dst[0])
然后就是一顿处理,只把我们所需的 city_name 和 city_code 这俩字段取出即可,随后写入文件中。如果读取的话就按照上面方法去读取,需要注意的是,使用 open()方法读取文件,得到的内容是一个列表,我们需要通过 eval()方法转化成 dict 类型。
这是把 city_name 和 city_code 放到一个文件中的方法,另外我们也可以放到数据库中,这里以 MySQL 为例,安装 PyMySQL 模块
import pymysql db_parames = { 'host': 'localhost', 'user': 'root', 'password': '123456', 'database': 'city_code_info' } #连接数据库 conn = pymysql.connect(**db_parames) #创建游标对象,增删改查都在游标上进行 cursor = conn.cursor() #表存在,就删除 cursor.execute("DROP TABLE IF EXISTS city_code") #建表语句 create_table_sql = """CREATE TABLE `city_code` ( `city_name` varchar(20) DEFAULT NULL, `city_code` varchar(25) DEFAULT NULL ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; """ #建表 cursor.execute(create_table_sql) #插入数据 with open('city_for_code.json','r+',encoding='utf-8') as f: origin_data = f.readlines() current_data = eval(origin_data[0]) #读取的内容是一个列表,且只包含一个元素 #print(current_data.get('北京','Not Exists.')) for name, code in current_data.items(): sql = """INSERT INTO city_code(city_name, city_code) VALUES ('%s', '%s')""" % (name, code) try: cursor.execute(sql) except: conn.rollback() conn.commit() conn.close()
执行这个 python 程序就可以将文件中的城市名跟城市码存到库中,当然我们也可以直接获取到城市名和城市码,然后跳过文件持久化这一步,直接把这两个字段取出存进去,但是考虑着代码要多练多写,就多此一举了一下。
下面是输入城市名就能得到城市码的代码块:
import pymysql def get_city_code(city_name): db_parames = { 'host': 'localhost', 'user': 'root', 'password': '123456', 'database': 'city_code_info' } #连接数据库 conn = pymysql.connect(**db_parames) #创建游标对象,增删改查都在游标上进行 cursor = conn.cursor() #创建查询语句 select_sql = "SELECT * FROM city_code where city_name='%s'"%(city_name) try: cursor.execute(select_sql) result = cursor.fetchall() for row in result: city_code = row[1] return city_code except: return "Error: unable fetch data!"
然后是根据输入的城市码来获取天气情况:
import requests def get_weather(city_name,get_date_time=3): city_code = get_city_code(city_name) url = 'http://t.weather.sojson.com/api/weather/city/%s'%(city_code) header = { 'user-agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/74.0.3729.169 Safari/537.36' } response = requests.get(url,header) response.encoding = 'utf-8' weather = response.json() day = {1: '明天', 2: '后天', 3: '大后天'} weather_lst = [] for num in range(get_date_time): City = weather["cityInfo"]["city"] Weatherganmao = weather["data"]["ganmao"] Weatherquality = weather["data"]["quality"] Weathershidu = weather["data"]["shidu"] Weatherwendu = weather["data"]["wendu"] Weatherpm25 = str(weather["data"]["pm25"]) Weatherpm10 = str(weather["data"]["pm10"]) Dateymd = weather["data"]["forecast"][num]["ymd"] Dateweek = weather["data"]["forecast"][num]["week"] Sunrise = weather["data"]["forecast"][num]["sunrise"] Sunset = weather["data"]["forecast"][num]["sunset"] Windfx = weather["data"]["forecast"][num]["fx"] Windf1 = weather["data"]["forecast"][num]["fl"] Weathertype = weather["data"]["forecast"][num]["type"] Weathernotice = weather["data"]["forecast"][num]["notice"] Weatherhigh = weather["data"]["forecast"][num]["high"] Weatherlow = weather["data"]["forecast"][num]["low"] if num == 0: result = '今日天气预报' + '\n' + '日期: ' + Dateymd + ' ' + Dateweek + ' ' + City + '\n' + '天气: ' + Weathertype + ' ' + Windfx + ' ' + Windf1 + ' ' + Weathernotice + '\n' + '当前温度: ' + Weatherwendu + '℃' + '\n' + '空气湿度: ' + Weathershidu + '\n' + '温度范围: ' + Weatherlow + '' + '~' + '' + Weatherhigh + '\n' + '污染指数: ' + 'PM2.5: ' + Weatherpm25 + ' ' + 'PM10: ' + Weatherpm10 + '\n' + '空气质量: ' + Weatherquality + '\n' + '日出时间: ' + Sunrise + '\n' + '日落时间: ' + Sunset + '\n' + '温馨提示: ' + Weatherganmao else: which_day = day.get(num,'超出范围') result = '\n' + which_day + ' ' + '天气预报' + '\n' + '日期: ' + Dateymd + ' ' + Dateweek + ' ' + City + '\n' + '天气: ' + Weathertype + ' ' + Windfx + ' ' + Windf1 + ' ' + Weathernotice + '\n' + '温度范围: ' + Weatherlow + '' + '~' + '' + Weatherhigh + '\n' + '日出时间: ' + Sunrise + '\n' + '日落时间: ' + Sunset + '\n' + '温馨提示: ' + Weatherganmao weather_lst.append(result) weather_str = '' #因为默认要输出三天的天气情况,所以我们需要创建一个空字符串,然后每迭代一次,就将天气情况拼接到空字符串中。 for msg in weather_lst: weather_str += msg + '\n' return weather_str
下面是发送微信消息
from wxpy import * def send_wx(city_name, who): bot = Bot(cache_path=True) #bot = Bot(console_qr=2, cache_path='botoo.pkl') my_friend = bot.friends().search(who)[0] msg = get_weather(city_name) try: my_friend.send(msg) except: my_friend = bot.friends().search('fei')[0] my_friend.send(u"发送失败")
然后我们还需要写一个定时器,每隔一段时间便要发送一次
from threading import Timer def auto_send(): city_name = '设置要发送的城市' friend_list = ['要发送的人'] for who in friend_list: send_wx(city_name,who) global timer timer = Timer(1,auto_send) timer.start()
最后执行程序
if __name__ == '__main__': timer = Timer(1,auto_send) timer.start()
以上就是python获取天气接口给指定微信好友发天气预报的详细内容,更多关于python获取天气接口的资料请关注其它相关文章!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新动态
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]