上一篇文章 在 SSIS 中使用 Web Service 以及 解析 XML 数据 中介绍了使用 SSIS 的 WebService 控件解析 XML 数据,最后也提到对于返回的 XML 数含有数组类型的时候需要一点额外的处理。
示例说明
WeatherWebService 是 WebXml.com.cn 天气预报 Web 服务,数据每 2.5 小时左右自动更新一次,准确可靠。包括 340 多个中国主要城市和 60 多个国外主要城市三日内的天气预报数据。
我们可以通过这个服务的接口获得我们需要的城市或地区的天气等信息。本示例将介绍在 SSIS 中用 Web 服务任务组件调用天气预报 Web 服务的接口查询城市的天气等信息,因为返回 XML 格式的数据含有数组,所以用 Foreach 循环容器组件的 NodeList 枚举器来处理,获取我们需要的信息插入到数据库的表。
实现步骤
HTTP 连接
首先我们建立一个 HTTP 连接,服务器 URL 如下:
http://www.webxml.com.cn/WebServices/WeatherWebService.asmx?wsdl
Web 服务任务
拖入 Web 服务任务组件,打开编辑器,在常规面板中,HttpConnection 连接选择上一步新建的 Http 连接,WSDLFile 为自己新建的一个 wsdl 格式的文件,OverwriteWSDLFile 为 True.点击【下载 WSDL】。
切换到输入面板,Method 中选择 getWeatherbyCityName,然后下面出现的变量里填一个城市名称,当然也可以用变量。
切换到输出面板,这里,我们将返回的 XML 格式的数据保存到一个 Object 类型的变量里。这样 Web 服务任务组件就设置好了。
返回数据说明
到 WeatherWebService 网站上查看 getWeatherbyCityName 的调用说明:
根据城市或地区名称查询获得未来三天内天气情况、现在的天气实况、天气和生活指数
调用方法如下:输入参数:theCityName = 城市中文名称(国外城市可用英文)或城市代码(不输入默认为上海市),如:上海 或 58367,如有城市名称重复请使用城市代码查询(可通过 getSupportCity 或 getSupportDataSet 获得);返回数据: 一个一维数组 String(22),共有 23 个元素。
String(0) 到 String(4):省份,城市,城市代码,城市图片名称,最后更新时间。String(5) 到 String(11):当天的 气温,概况,风向和风力,天气趋势开始图片名称(以下称:图标一),天气趋势结束图片名称(以下称:图标二),现在的天气实况,天气和生活指数。String(12) 到 String(16):第二天的 气温,概况,风向和风力,图标一,图标二。String(17) 到 String(21):第三天的 气温,概况,风向和风力,图标一,图标二。String(22) 被查询的城市或地区的介绍
可以看到返回的是一个一维数组。
我们将用循环处理这个一维数组,然后获得我们需要的字段,比如省份,城市,城市代码,最后更新时间,当天气温,概况,风向和风力,现在的天气实况,天气和生活指数。
Foreach 循环容器
在控制流中拖入 Foreach 循环容器,双击打开编辑器,在集合面板中,Enumerator 选择 Foreach NodeList 枚举器,DocumentSourceType 为输入的 XML 数据存储类型,这里选择上一步的保存 XML 数据的变量,DocumentSource 为变量名称。
EnumerationType 选择 NodeText,因为这里我们想要的是 XML 数据中标签中的值,不是节点。OuterXPathStringSourceType 是 XPath 查询的类型,这里我们选 DirectInput,然后 OuterXPathString 是我们查询 XML 的节点语法,这里填/ArrayOfString/*,它表示查询 XML 数据中的 ArrayOfString 这个节点下的所有节点,具体的 XPath 语法可以参考 XPath 教程。
切换到变量映射面板,这里新建一个变量保存每次循环取到节点的时候,节点里的值。这样,Foreach 循环容器设置就完成了。
信息输出
为方便演示,我就不连接数据库了,把获取到的信息显示出来就好了。将一个脚本任务拖入到 Foreach 循环容器里面。双击打开编辑器,脚本类型这里用的 VBA,然后新建了连个变量:ID,InfoStr,ID 是每次循环的下标值,依次加 1,InfoStr 保存组合成的信息值。然后在 ReadWriteVariables 里添加进来。点击【编辑脚本】,打开脚本编辑器,输入处理代码。
最后将组合信息字符串输出,还是拖入一个脚本任务,编辑器设置如下:
最后执行包任务,可以看到输出的信息。
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于