2012年3月22日,发了一条关于Excel通过API接口批量获取天气记录的微博,现在博客上做个总结,并对此文件的实现方法做个简要教程供大家学习参考。微博内容如下:
利用Excel快速批量获取并保存城市天气记录,如果不选择省市,则获取全国所有城市的天气信息,保存好以后能够方便地对历史天气情况进行跟踪分析等应用,数据来源于新浪天气API接口。查看大图看动画效果。通过@微盘分享文件"批量获取城市天气记录.rar"
http://t.cn/zOiXggN
有很多网友希望学习Excel通过API接口获取网页即时数据的方法,比如刘万祥ExcelPro:从web获取实时数据,制作自动报告,将是excel的新用法,值得学习!期待教程~~
下面就简要介绍一下此文件的制作方法。
使用Alt+F11可以看到此文件的所有VBA源代码,在模块中有两个Sub过程:get_xmldoc(city,
xmldoc)和get_today_weather(),分别用于从网页获取指定城市的天气信息和获取今日天气。
首先看如何从网页获取指定城市的天气信息,get_xmldoc(city,
xmldoc)有两个参数:city是输入参数、xmldoc是输出参数,用CreateObject("Msxml2.XMLHTTP")创建对象,从http://php.weather.sina.com.cn/xml.php网站上获取天气信息,由于.responseText是文本,故采用.LoadXML来将其转换为方便调用的XML格式(原计划用.respons