Python實現天氣查詢功能(外加Excel技巧)

ZackSock發表於2019-10-16

昨天在網上發現了一個非常方便的天氣API,就用Python試著用了一下。引數是挺少的,用起來也方便,但是那個城市程式碼確實是搞了我好長時間。

一、介紹

我們先來看一下實現的程式有什麼功能:
在這裡插入圖片描述
功能也是非常簡單的,輸入城市,顯示當前城市、當前日期時間、溫度和天氣。

API使用的是國家氣象局的介面,完全免費的:
http://t.weather.sojson.com/api/weather/city/101010100
這個是以北京為例的介面,其中最後的數字101010100就是北京的城市程式碼。查詢其它城市只需要把城市程式碼修改成其它城市的就可以了。

因為這個API的訪問只能通過城市程式碼,在這方面還是有點麻煩的,不過我把城市程式碼整理出了一個json檔案,稍後會為大家講解這個過程。

二、返回資料

這裡以南昌為例,因為返回的資料比較多,就不完整的列舉了。請求成功時,大致資料如下:
在這裡插入圖片描述
裡面還有很多沒有拉開的地方,然後我們嘗試訪問一個錯誤的城市程式碼:
http://t.weather.sojson.com/api/weather/city/1
其中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"])
    print("天氣:", d["data"]["forecast"][0]["type"])

程式碼方面沒有特別難的地方,就是在輸出的時候需要自己對json資料有一些瞭解,然後根據自己需要的內容,輸出即可。自己可以嘗試請求,然後用HiJson格式化一下,或者也有許多線上格式化的網址,然後分析自己需要的資料。

三、將城市程式碼轉為json資料(Excel技巧)

接下來講講我是如下和城市程式碼鬥爭的,下面這段大家可以不用看。程式碼中使用到的city.json檔案我會在文末上傳。

因為我沒有找到獲取城市程式碼的介面,只找到了下面這段文字:

北京:101010100朝陽:101010300順義:101010400懷柔:101010500通州:101010600昌平:101010700延慶:101010800豐臺:101010900石景山:101011000大興:101011100房山:101011200密雲:101011300門頭溝:101011400平谷:101011500八達嶺:101011600佛爺頂:101011700湯河口:101011800密雲上甸子:101011900齋堂:101012000霞雲嶺:101012100北京城區:101012200海淀:101010200天津:101030100寶坻:101030300東麗:101030400西青:101030500北辰:101030600薊縣:101031400漢沽:101030800靜海:101030900津南:101031000塘沽:101031100大港:101031200武清:101030200寧河:101030700上海:101020100寶山:101020300嘉定:101020500南匯:101020600浦東:101021300青浦:101020800松江:101020900奉賢:101021000崇明:101021100徐家彙:101021200閔行:101020200金山:101020700石家莊:101090101張家口:101090301承德:101090402唐山:101090501秦皇島:101091101滄州:101090701衡水:101090801邢臺:101090901邯鄲:101091001保定:101090201廊坊:101090601鄭州:101180101新鄉:101180301許昌:101180401平頂山:101180501信陽:101180601南陽:101180701開封:101180801洛陽:101180901商丘:101181001焦作:101181101鶴壁:101181201濮陽:101181301周口:101181401漯河:101181501駐馬店:101181601三門峽:101181701濟源:101181801安陽:101180201合肥:101220101蕪湖:101220301淮南:101220401馬鞍山:101220501安慶:101220601宿州:101220701阜陽:101220801亳州:101220901黃山:101221001滁州:101221101淮北:101221201銅陵:101221301宣城:101221401六安:101221501巢湖:101221601池州:101221701蚌埠:101220201杭州:101210101舟山:101211101湖州:101210201嘉興:101210301金華:101210901紹興:101210501台州:101210601溫州:101210701麗水:101210801衢州:101211001寧波:101210401重慶:101040100合川:101040300南川:101040400江津:101040500萬盛:101040600渝北:101040700北碚:101040800巴南:101040900長壽:101041000黔江:101041100萬州天城:101041200萬州龍寶:101041300涪陵:101041400開縣:101041500城口:101041600雲陽:101041700巫溪:101041800奉節:101041900巫山:101042000潼南:101042100墊江:101042200梁平:101042300忠縣:101042400石柱:101042500大足:101042600榮昌:101042700銅梁:101042800璧山:101042900豐都:101043000武隆:101043100彭水:101043200綦江:101043300酉陽:101043400秀山:101043600沙坪壩:101043700永川:101040200福州:101230101泉州:101230501漳州:101230601龍巖:101230701晉江:101230509南平:101230901廈門:101230201寧德:101230301莆田:101230401三明:101230801蘭州:101160101平涼:101160301慶陽:101160401武威:101160501金昌:101160601嘉峪關:101161401酒泉:101160801天水:101160901武都:101161001臨夏:101161101合作:101161201白銀:101161301定西:101160201張掖:101160701廣州:101280101惠州:101280301梅州:101280401汕頭:101280501深圳:101280601珠海:101280701佛山:101280800肇慶:101280901湛江:101281001江門:101281101河源:101281201清遠:101281301雲浮:101281401潮州:101281501東莞:101281601中山:101281701陽江:101281801揭陽:101281901茂名:101282001汕尾:101282101韶關:101280201南寧:101300101柳州:101300301來賓:101300401桂林:101300501梧州:101300601防城港:101301401貴港:101300801玉林:101300901百色:101301001欽州:101301101河池:101301201北海:101301301崇左:101300201賀州:101300701貴陽:101260101安順:101260301都勻:101260401興義:101260906銅仁:101260601畢節:101260701六盤水:101260801遵義:101260201凱里:101260501昆明:101290101紅河:101290301文山:101290601玉溪:101290701楚雄:101290801普洱:101290901昭通:101291001臨滄:101291101怒江:101291201香格里拉:101291301麗江:101291401德巨集:101291501景洪:101291601大理:101290201曲靖:101290401保山:101290501呼和浩特:101080101烏海:101080301集寧:101080401通遼:101080501阿拉善左旗:101081201鄂爾多斯:101080701臨河:101080801錫林浩特:101080901呼倫貝爾:101081000烏蘭浩特:101081101包頭:101080201赤峰:101080601南昌:101240101上饒:101240301撫州:101240401宜春:101240501鷹潭:101241101贛州:101240701景德鎮:101240801萍鄉:101240901新餘:101241001九江:101240201吉安:101240601武漢:101200101黃岡:101200501荊州:101200801宜昌:101200901恩施:101201001十堰:101201101神農架:101201201隨州:101201301荊門:101201401天門:101201501仙桃:101201601潛江:101201701襄樊:101200201鄂州:101200301孝感:101200401黃石:101200601咸寧:101200701成都:101270101自貢:101270301綿陽:101270401南充:101270501達州:101270601遂寧:101270701廣安:101270801巴中:101270901瀘州:101271001宜賓:101271101內江:101271201資陽:101271301樂山:101271401眉山:101271501涼山:101271601雅安:101271701甘孜:101271801阿壩:101271901德陽:101272001廣元:101272101攀枝花:101270201銀川:101170101中衛:101170501固原:101170401石嘴山:101170201吳忠:101170301西寧:101150101黃南:101150301海北:101150801果洛:101150501玉樹:101150601海西:101150701海東:101150201海南:101150401濟南:101120101濰坊:101120601臨沂:101120901菏澤:101121001濱州:101121101東營:101121201威海:101121301棗莊:101121401日照:101121501萊蕪:101121601聊城:101121701青島:101120201淄博:101120301德州:101120401煙臺:101120501濟寧:101120701泰安:101120801西安:101110101延安:101110300榆林:101110401銅川:101111001商洛:101110601安康:101110701漢中:101110801寶雞:101110901咸陽:101110200渭南:101110501太原:101100101臨汾:101100701運城:101100801朔州:101100901忻州:101101001長治:101100501大同:101100201陽泉:101100301晉中:101100401晉城:101100601呂梁:101101100烏魯木齊:101130101石河子:101130301昌吉:101130401吐魯番:101130501庫爾勒:101130601阿拉爾:101130701阿克蘇:101130801喀什:101130901伊寧:101131001塔城:101131101哈密:101131201和田:101131301阿勒泰:101131401阿圖什:101131501博樂:101131601克拉瑪依:101130201拉薩:101140101山南:101140301阿里:101140701昌都:101140501那曲:101140601日喀則:101140201林芝:101140401臺北縣:101340101高雄:101340201臺中:101340401海口:101310101三亞:101310201東方:101310202臨高:101310203澄邁:101310204儋州:101310205昌江:101310206白沙:101310207瓊中:101310208定安:101310209屯昌:101310210瓊海:101310211文昌:101310212保亭:101310214萬寧:101310215陵水:101310216西沙:101310217南沙島:101310220樂東:101310221五指山:101310222瓊山:101310102長沙:101250101株洲:101250301衡陽:101250401郴州:101250501常德:101250601益陽:101250700婁底:101250801邵陽:101250901岳陽:101251001張家界:101251101懷化:101251201黔陽:101251301永州:101251401吉首:101251501湘潭:101250201南京:101190101鎮江:101190301蘇州:101190401南通:101190501揚州:101190601宿遷:101191301徐州:101190801淮安:101190901連雲港:101191001常州:101191101泰州:101191201無錫:101190201鹽城:101190701哈爾濱:101050101牡丹江:101050301佳木斯:101050401綏化:101050501黑河:101050601雙鴨山:101051301伊春:101050801大慶:101050901七臺河:101051002雞西:101051101鶴崗:101051201齊齊哈爾:101050201大興安嶺:101050701長春:101060101延吉:101060301四平:101060401白山:101060901白城:101060601遼源:101060701松原:101060801吉林:101060201通化:101060501瀋陽:101070101鞍山:101070301撫順:101070401本溪:101070501丹東:101070601葫蘆島:101071401營口:101070801阜新:101070901遼陽:101071001鐵嶺:101071101朝陽:101071201盤錦:101071301大連:101070201錦州:101070701 

先將這段文字複製下來,然後開啟Excel,選中一個單元,貼上。就會有如下效果:
在這裡插入圖片描述
然後我們點選北京,拖動橫向滾動條,按住shift,點選最後一個資料:
在這裡插入圖片描述
這樣就把整個資料全選了。然後複製,點選北京下面一個單元格。右擊->選擇性複製->勾選轉置:
在這裡插入圖片描述
轉置後效果如下,在這裡插入圖片描述
但是這樣有一個明顯的問題,北京對應的是101010100。而上面是朝陽和101010100在一起,而且在同一單元格。我們先把資料拆成兩單元格。在“101010100朝陽”單元格,選中“101010100”。複製到右邊(注意要先將格式設定為文字):單元格1,再選擇“朝陽”,複製到下一個單元格:單元格2,然後分別點選單元格1、單元格2,按ctrl+E,就有如下效果:
在這裡插入圖片描述

資料都被分開了,然後我們把多餘資料刪除。我們選中左邊列的資料(點開頭,按shift,點結尾),剪下,然後點選上一個單元格,複製:
在這裡插入圖片描述
然後就對齊了,現在我們再轉置回去。點選左上角、按住shift、點選右下角(有資料的區域),然後複製->點選一個空白單元格->選擇性貼上->轉置:在這裡插入圖片描述
我把兩行對換位置,然後轉置的。轉置之後,我們將有效資料(橫向的資料)複製。然後開啟瀏覽器:
http://www.bejson.com/json/col2json/
使用這個網址,將內容複製進去,點轉換就好了。效果如下,我們只需要將json文字儲存一個檔案就好了。在這裡插入圖片描述
雖然API的請求確實是非常方便,但是把這個城市程式碼確實麻煩。

程式碼和檔案還用HiJson我都上傳了百度雲:
連結:https://pan.baidu.com/s/1_sGBFm0NNWgVxiM2HQL12Q
提取碼:o5ay

相關文章