在 SSIS 中,如何在 Foreach NodeList 枚举器中使用 XPATH 循环遍历特定元素内的 XML

Posted

技术标签:

【中文标题】在 SSIS 中,如何在 Foreach NodeList 枚举器中使用 XPATH 循环遍历特定元素内的 XML【英文标题】:In SSIS, how to loop through the XML inside a specific element using XPATH in a Foreach NodeList Enumerator 【发布时间】:2015-11-19 09:44:24 【问题描述】:

我正在尝试遍历 SSIS 中 XML 输入文件的 XML 元素。 为此,我尝试将“Foreach 循环容器”与 Foreach 循环容器一起使用。在 ForEach 循环容器中,我想将 xml 代码作为字符串变量获取。

我是 SSIS 的新手,已经浏览了很长一段时间的网页,但还是无法正确使用..

输入文件示例; (注意里面有一些西里尔符号,这可能会导致问题。但是,当我取出西里尔符号时,会显示相同的错误消息。

我正在尝试遍历节点。

这是我目前创建的包;

在 ForEach 循环下; 我有一个名为“CurrencyRate”的变量,它是一个映射到那里的字符串。

还有循环内的 XML 任务。这仅用于测试目的,它应该将最后一个节点元素写入该输出文件,带有标签和值。

但是,如果我按原样运行代码,我会收到以下错误消息,即使我在数据中看不到任何 NULL 值。而且我不知道日本(?)符号来自哪里......;

任何帮助将不胜感激! SSIS 看起来像一个强大的工具,我希望能够使用它。

【问题讨论】:

【参考方案1】:

我现在使用 Foreach From Variable Enumerator 而不是 Foreach NodeList 枚举器。

这是整个包裹;

使用以下变量;

在第一个脚本任务'CurrencyRates from XML to Array'中使用以下脚本; 此代码将获取 XML 并将每个节点作为对象放入数组中。然后将该数组传递给对象变量。

        public void Main()
    
        // TODO: Add your code here

        System.Collections.ArrayList arr = new System.Collections.ArrayList();

        XmlDocument doc = new XmlDocument();
        doc.Load((String)Dts.Variables["User::file_path"].Value + Dts.Variables["User::file_name"].Value);
        XmlElement root = doc.DocumentElement;
        XmlNodeList nodes = root.SelectNodes("//CurrencyRate"); // You can also use XPath here
        foreach (XmlNode CurrencyRate in nodes)
        
            arr.Add((String)CurrencyRate.InnerXml);
        


        Dts.Variables["User::CurrencyRates"].Value = arr;

        Dts.TaskResult = (int)ScriptResults.Success;
    

然后使用 Foreach From Variable Enumerator 循环该对象变量,将节点映射到对象变量“CurrencyRate_Item”。 在循环中,这个项目被移动到一个字符串变量中,然后我们可以根据需要使用它。

【讨论】:

感谢您花时间发布详细的解决方案。你今天让互联网变得更智能了。

以上是关于在 SSIS 中,如何在 Foreach NodeList 枚举器中使用 XPATH 循环遍历特定元素内的 XML的主要内容,如果未能解决你的问题,请参考以下文章

使用 SSIS Foreach Loop 容器 – Foreach Item Enumerator

如何遍历 Excel 文件并使用 SSIS 包将它们加载到数据库中?

在 SSIS 中使用 For Each Loop 容器时如何检查点

我可以在 SSIS 中抑制“对于每个文件的枚举器为空”警告吗?

在 SSIS 中运行时根据源文件夹选择数据库名称

如何使用 Node.js 在 MongoDB 中使用 cursor.forEach()?