看一下我们已经拿到的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。
虽然看上去像字典,但它对于程序来说,仍然是一个字符串,只不过是一个满足json格式的字符串。我们用python中提供的另一个模块json提供的loads方法,把它转成一个真正的字典。
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 '没有找到该城市'