查天气(3)

看一下我们已经拿到的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 '没有找到该城市'

你可能感兴趣的:(查天气(3))