0

我有一个 BizTalk 映射问题,我需要将数据从源架构复制到目标架构,但有一个条件。

我想复制 3 个具有相同名称的节点中的值,但一个值除外。让我解释得更好。

举个例子:

<testxml>
    <node>abc</node>
    <node>def</node>
    <node>ghi</node>
    <node>jkl</node>
</testxml>

使用字符串连接,我设法将目标架构上的数据获取到以下内容:

<testxml>
    <node>abcdefghijkl</node>
</testxml>

但是我希望输出类似于以下内容:

<testxml>
    <node>abcdefjkl</node>
</testxml>

因此,我从输出中提取值“ghi”。

有什么办法可以做到这一点?

注意:我不能使用字符串提取,因为我需要提取的文本位于字符串的中间

4

3 回答 3

2

这是“最干净”的解决方案(请注意脚本 functoid 很危险,因为它在某些情况下会导致内存泄漏,例如大文件,您必须仅在极端情况下使用它,此处提供更多详细信息https://support.microsoft.com/en -us/kb/918643),现在对于您的问题,您可以通过组合不等于运算符(您基本上告诉您的元素不应该等于 JKL 或其他)然后添加一个累积连接 functoid 来做到这一点,您将拥有在您的输出中,您的所有字符串都连接在一起,除了不应该的字符串

在此处输入图像描述

您可以在附件中找到我制作的一个小示例 Sample Demo

于 2015-08-06T13:23:58.617 回答
1

这可以通过脚本 functoid 和一些自定义内联 XSLT轻松实现:

BizTalk 映射器脚本 functoid

<xsl:variable name="outputval" select="concat(//node[1],//node[2],//node[4])" />

<xsl:element name="node">
<xsl:value-of select="$outputval" />
</xsl:element>
于 2015-08-06T12:25:03.153 回答
0

我为解决此问题所做的是使用自定义正则表达式 C# 脚本:

public String Trim(String Input) {
    String Output = Regex.Replace(Input, "ghi","");
return Output;
}

在此处输入图像描述

这解决了我删除不需要的字符串值的问题。正如 Jeroen Maes 指出的那样,这也可以通过使用自定义 Functoid 脚本的内联 XSLT 来完成。

两种解决方案都提供以下输出:

<testxml>
    <node>abcdefjkl</node>
</testxml>
于 2015-08-06T13:10:45.897 回答