看一下我们已经拿到的json格式的天气数据: 1. { 2. "weatherinfo": { 3. "city": "南京", 4. "cityid": "101190101", 5. "temp1": "37℃", 6. "temp2": "28℃", 7. "weather": "多云", 8. "img1": "d1.gif", 9. "img2": "n1.gif", 10. "ptime": "11:00" 11. } 12. } 复制代码 直接在命令行中看到的应该是没有换行和空格的一长串字符,这里我把格式整理了一下。可以看出,它像是一个字典的结构,但是有两层。最外层只有一个key--“weatherinfo”,它的value是另一个字典,里面包含了好几项天气信息,现在我们最关心的就是其中的temp1,temp2和weather。 1. import json 2. 3. data = json.loads(content) 复制代码 这时候的data已经是一个字典,尽管在控制台中输出它,看上去和content没什么区别,只是编码上有些不同: 1. {u'weatherinfo': {u'city': u'\u5357\u4eac', u'ptime': u'11:00', u'cityid': u'101190101', u'temp2': u'28\u2103', u'temp1': u'37\u2103', u'weather': u'\u591a\u4e91', u'img2': u'n1.gif', u'img1': u'd1.gif'}} 复制代码 但如果你用type方法看一下它们的类型: 1. print type(content) 2. print type(data) 3. 复制代码 就知道区别在哪里了。 1. result = data['weatherinfo'] 2. str_temp = ('%s\n%s ~ %s') % ( 3. result['weather'], 4. result['temp1'], 5. result['temp2'] 6. ) 7. print str_temp 复制代码 为了防止在请求过程中出错,我加上了一个异常处理。 1. try: 2. ### 3. ### 4. except: 5. print '查询失败' 复制代码 以及没有找到城市时的处理: 1. if citycode: 2. ### 3. ### 4. else: 5. print '没有找到该城市' 复制代码
1. # -*- coding: utf-8 -*- 2. import urllib2 3. import json 4. from city import city 5. 6. cityname = raw_input('你想查哪个城市的天气?\n') 7. citycode = city.get(cityname) 8. if citycode: 9. try: 10. url = ('http://www.weather.com.cn/data/cityinfo/%s.html' 11. % citycode) 12. content = urllib2.urlopen(url).read() 13. data = json.loads(content) 14. result = data['weatherinfo'] 15. str_temp = ('%s\n%s ~ %s') % ( 16. result['weather'], 17. result['temp1'], 18. result['temp2'] 19. ) 20. print str_temp 21. except: 22. print '查询失败' 23. else: 24. print '没有找到该城市' |
|