溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

怎么用python自制微信機器人定時發(fā)送天氣預(yù)報

發(fā)布時間:2021-04-25 14:19:35 來源:億速云 閱讀:343 作者:小新 欄目:開發(fā)技術(shù)

這篇文章給大家分享的是有關(guān)怎么用python自制微信機器人定時發(fā)送天氣預(yù)報的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

python有哪些常用庫

python常用的庫:1.requesuts;2.scrapy;3.pillow;4.twisted;5.numpy;6.matplotlib;7.pygama;8.ipyhton等。

0 引言

wxpy基于itchat,使用了 Web 微信的通訊協(xié)議,通過大量接口優(yōu)化提升了模塊的易用性,并進行豐富的功能擴展。實現(xiàn)了微信登錄、收發(fā)消息、搜索好友、數(shù)據(jù)統(tǒng)計、微信公眾號、微信好友、微信群基本信息獲取等功能。

1 環(huán)境

操作系統(tǒng):Windows / Linux

Python版本:3.7.2

2 代碼實現(xiàn)

我們要實現(xiàn)用Python來發(fā)微信,發(fā)送的內(nèi)容是每天最新的天氣信息。很明顯我們需要完成兩部分的準(zhǔn)備,先來看看獲取天氣信息這部分內(nèi)容。

2.0 準(zhǔn)備工作

本文我們用到的第三方庫有requests、wxpyy,若環(huán)境還沒有,按如下方式進行安裝即可。

pip install wxpy
pip install requests

 2.1 獲取天氣信息

這里我使用的API的請求鏈接如下:

http://t.weather.sojson.com/api/weather/city/city_code

請求方式是GET方法,使用時注意更換為自己城市對應(yīng)的city_code,除此之外不用帶任何參數(shù)。

請求是restfull風(fēng)格,city_code為9位數(shù)字,如下示例:

{
 "_id": 58,
 "id": 59,
 "pid": 3,
 "city_code": "101230201",
 "city_name": "廈門"
}

大家可以從_city.json文件中獲取各個城市對應(yīng)的編號。該文件我已經(jīng)放在Github本文章對應(yīng)的目錄下了,大家可自行查詢使用。

# weather API的URL,此處的城市編號,參看_city.json
url = 'http://t.weather.sojson.com/api/weather/city/101010200'
header = {
 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/73.0.3683.75 Safari/537.36'
}

# 請求Weather API并拿到服務(wù)器返回的數(shù)據(jù)
rep = requests.get(url, headers = header)
rep.encoding = "utf-8"
result = ''
weather = rep.tex

這個API接口的返回值內(nèi)容很多,以下僅展示返回的部分信息。實際使用中僅用到三塊內(nèi)容,首先是城市信息。

"cityInfo": {
 "city": "海淀區(qū)", //請求城市
 "cityId": "101010200", //城市ID
 "parent": "北京市", //上級,一般是省份
 "updateTime": "09:02" //天氣更新時間
}

其次是,該城市當(dāng)前天氣的空氣相關(guān)指數(shù)。

"data": {
 "shidu": "32%", //濕度
 "pm25": 35.0, //pm2.5
 "pm10": 97.0, //pm10
 "quality": "良", //空氣質(zhì)量
 "wendu": "7", //溫度
 "ganmao": "極少數(shù)敏感人群應(yīng)減少戶外活動", //感冒提醒(指數(shù))
}

第三部分,該城市當(dāng)前天氣的溫度風(fēng)力等另外一些指數(shù)。

"forecast": [ //今天+未來14天
 {
  "date": "16", //日期
  "sunrise": "06: 28",
  "high": "高溫 20.0℃",
  "low": "低溫 2.0℃",
  "sunset": "18: 21",
  "aqi": 48.0, 
  "ymd": "2019-03-16", //年月日
  "week": "星期六",
  "fx": "西北風(fēng)", //風(fēng)向
  "fl": "3-4級", //風(fēng)力
  "type": "晴",
  "notice": "愿你擁有比陽光明媚的心情"
 }
]

注:這個API接口返回值完整的示例,請見Github中本文章目錄下的weather.json文件。

拿到返回值之后,需要解析,并轉(zhuǎn)換組裝成我們想要的格式。

# 解析服務(wù)器返回的數(shù)據(jù),具體可參考weather.json文件
index_cityInfo = weather.find("cityInfo")
index_cityId = weather.find("cityId")
index_shidu = weather.find("shidu")
index_pm25 = weather.find("pm25")
index_pm10 = weather.find("pm10")
index_quality = weather.find("quality")
index_wendu = weather.find("wendu")
index_ganmao = weather.find("ganmao")
index_forecast = weather.find("forecast")
index_ymd = weather.find("ymd", index_forecast)
index_week = weather.find("week", index_forecast)
index_sunset = weather.find("sunset", index_forecast)
index_high = weather.find("high", index_forecast)
index_low = weather.find("low", index_forecast)
index_fx = weather.find("fx", index_forecast)
index_fl = weather.find("fl", index_forecast)
index_aqi = weather.find("aqi", index_forecast)
index_type = weather.find("type", index_forecast)
index_notice = weather.find("notice", index_forecast)

這是我最終想達(dá)到的效果如下:

# 今日天氣預(yù)報
# 年月日 + 星期 + 所在地城市
# 天氣類型 + 風(fēng)向 + 風(fēng)力
# 溫度范圍(最低溫度~最高溫度)
# 污染指數(shù):PM2.5/PM10/AQI
# 空氣質(zhì)量
# 當(dāng)前溫度 + 空氣濕度
# Notice信息

 轉(zhuǎn)換化具體代碼就是這樣子的:

result = '今日天氣預(yù)報' + '\n' \
 + weather[index_ymd + 6:index_week - 3] + " " \
 + weather[index_week + 7:index_fx - 3] + " " \
 + weather[index_cityInfo + 19:index_cityId - 3] + '\n' \
 + "天氣: " + weather[index_type + 7:index_notice - 3] + " " \
 + weather[index_fx + 5:index_fl - 3] \
 + weather[index_fl + 5:index_type - 3] + '\n' \
 + "溫度范圍:" + weather[index_low + 9:index_sunset - 3] + " ~" \
 + weather[index_high + 10:index_low - 3] + '\n' \
 + "污染指數(shù): PM2.5:" + weather[index_pm25 + 6:index_pm10 - 1] + "" \
 + "PM10:" + weather[index_pm10 + 6:index_quality - 1] + " " \
 + "AQI:" + weather[index_aqi + 5:index_ymd - 2] + '\n' \
 + "空氣質(zhì)量:" + weather[index_quality + 10:index_wendu - 3] + '\n' \
 + "當(dāng)前溫度:" + weather[index_wendu + 8:index_ganmao - 3] + " " \
 + "空氣濕度:" + weather[index_shidu + 8:index_pm25 - 3] + '\n' \
 + weather[index_notice + 9:weather.find('}', index_notice) - 1]

這樣我們的第一步,獲取天氣信息就完成了。接下來就是登錄微信定時發(fā)送消息了。

2.2 登錄微信定時發(fā)送消息

首先要登錄微信,一行代碼就搞定了。這里實際上是掃二維碼登錄了一個Web版的微信。

# 初始化機器人,掃碼登陸微信,適用于Windows系統(tǒng)
bot = Bot()

# Linux系統(tǒng),執(zhí)行登陸請調(diào)用下面的這句
bot = Bot(console_qr=2, cache_path="botoo.pkl")

然后我們需要定義一個發(fā)送消息的函數(shù),將獲取并解析好的天氣信息發(fā)送給指定微信好友。

# 調(diào)用get_weather函數(shù)
GW = get_weather()
# 填入你朋友的微信昵稱,注意這里不是備注,也不是微信帳號
my_friend = bot.friends().search(u'一個昵稱')[0]
# 發(fā)送微信消息
my_friend.send(u"早上好Y(^o^)Y,這里是今日份的天氣信息請查收!")
my_friend.send(GW) 
my_friend.send(u"Have a Nice Day!")

# 每隔86400秒(1天),發(fā)送1次
t = Timer(86400, auto_send)
t.start()

接下來,你可以使用try...except...語句來實現(xiàn)在消息失敗時發(fā)出告警:

try:
 '''此處為發(fā)送消息的代碼,即上一段內(nèi)容'''
except:
 # 你的微信昵稱,注意這里不是備注,也不是微信帳號
 my_friend = bot.friends().search('&嫻敲棋子&')[0]
 my_friend.send(u"報告老板,今日份的信息發(fā)送失敗了!")

最后運行主函數(shù),調(diào)用發(fā)送消息的函數(shù)即可。

# 調(diào)用函數(shù)進行消息發(fā)送
auto_send()

3 效果展示

這是我清晨收到的微信消息截圖,看上去還不錯。沒白忙活?

怎么用python自制微信機器人定時發(fā)送天氣預(yù)報

感謝各位的閱讀!關(guān)于“怎么用python自制微信機器人定時發(fā)送天氣預(yù)報”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI