python實現(xiàn)自主查詢實時天氣
更新時間:2018年06月22日 11:58:52 作者:So_What1412
這篇文章主要為大家詳細介紹了python實現(xiàn)自主查詢實時天氣,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了python實現(xiàn)自主查詢實時天氣的具體代碼,供大家參考,具體內(nèi)容如下
用到了urllib2 json 很簡單的一個應用 如下
獲取城市編號
#coding=utf-8 import urllib2 url1 = 'http://m.weather.com.cn/data3/city.xml' content1 = urllib2.urlopen(url1).read() provinces = content1.split(',') print content1 # 輸出content1可以查看全部省份代碼 result = '' url = 'http://m.weather.com.cn/data3/city%s.xml' for p in provinces: p_code = p.split('|')[0] url2 = url % p_code content2 = urllib2.urlopen(url2).read() # 輸出content2可以查看此省份下所有城市代碼 cities = content2.split(',') print content2 for c in cities: c_code = c.split('|')[0] url3 = url % c_code content3 = urllib2.urlopen(url3).read() print content3 #content3是此城市下所有地區(qū)代碼 districts = content3.split(',') for d in districts: # 對于每個地區(qū),我們把它的名字記錄下來,然后再發(fā)送一次請求,得到它的最終代碼: d_pair = d.split('|') d_code = d_pair[0] # if 5 == len(d_code): continue temp=[d_code] temp.insert(4,0) d_code ="".join(temp) name = d_pair[1] # 名字 url4 = url % d_code content4 = urllib2.urlopen(url4).read() print content4 code = content4.split('|')[1] line = "%s:%s\n" % (name, code) result += line print name + ':' + code f = file('./city', 'w') f.write(result) f.close()
findweather
# -*- coding: utf-8 -*- import urllib2 import json city = {} f =file('city','r') src = f.readlines() for line in src: line = line.split('\n')[0] name = line.split(':')[0] code = line.split(':')[1] city[name] = code cityname = raw_input('請輸入你要查詢的城市名稱:\n') citycode = city.get(cityname) print cityname if citycode: try: url = ('http://www.weather.com.cn/data/cityinfo/%s.html' % citycode) content = urllib2.urlopen(url).read() data = json.loads(content) result = data['weatherinfo'] str_temp = ('%s\n%s ~ %s') % (result['weather'],result['temp1'],result['temp2']) print str_temp except: print '查詢失敗' else: print '沒有找到該城市'
運行 findweather 即可。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
python處理 yaml 時保持輸入輸出格式一致的問題記錄
這篇文章主要介紹了python處理 yaml 時保持輸入輸出格式一致的問題記錄,要想保持順序不變在dump時添加sort_keys=False,使yaml格式保持原來的排序,本文給大家介紹的非常詳細,需要的朋友可以參考下2024-06-06僅用500行Python代碼實現(xiàn)一個英文解析器的教程
這篇文章主要介紹了僅用500行Python代碼實現(xiàn)一個英文解析器的教程,自然語言處理近來也是業(yè)界中一個熱門課題,作者為NLP方向的開發(fā)者,需要的朋友可以參考下2015-04-04python KNN算法實現(xiàn)鳶尾花數(shù)據(jù)集分類
這篇文章主要介紹了python KNN算法實現(xiàn)鳶尾花數(shù)據(jù)集分類,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-10-10