接受非数字字符的XPath条件。

问题描述 投票:0回答:2

我目前正在SAP PI(接收方确定对象)中构造一个XPath条件,该条件应该将消息路由到接收方1或接收方2。

企业发送的给定documentID值如下。

接收方1接收到低于documentID范围内的消息。

Range: "F00" to "F99"

接收器2接收低于documentID范围内的信息。

Range: "FA0" to "FZ9"

我能想到的示例条件,但不知道这样做是否可行,逻辑是否正确。还有一个后续问题,greatless than符号是否接受非数字字符?

接收器1的条件

(/p1:Upload/ContainerEvent[WorkAssignmentID >= F00] EX  AND /p1:Upload/ContainerEvent[WorkAssignmentID <= F99] EX ) 

接收器2的条件

(/p1:Upload/ContainerEvent[WorkAssignmentID >= FA0] EX  AND /p1:Upload/ContainerEvent[WorkAssignmentID <= FZ9] EX ) 

我也在考虑子串是否可以用在XPath中。欢迎提供您的意见。谢谢你的意见。

致敬,Charles Tan

xpath conditional-statements sap sap-xi sap-pi
2个回答
0
投票

回答您的后续问题("greatless than符号是否接受非数字字符?"):在XPath 1.0中,不接受,greatless-than只对数字进行操作。在XPath 2.0中,这种情况有所改变。


2
投票

纯XPath 1.0的解决方案。

接收器1接收到的消息在以下文档ID范围内 范围: F00到F99

/*/Upload/ContainerEvent
               [WorkAssignmentId
                 [string-length() = 3]
                 [starts-with(., 'F')][substring(.,2,2) >= 0][99 >= substring(.,2,2)]
                ]/EX

接收机2接收低于documentID范围内的信息范围:FA0至FZ9。FA0至FZ9

/*/Upload/ContainerEvent
               [WorkAssignmentId
                   [string-length() = 3]
                   [starts-with(., 'F')] 
                   [26 > string-length(
                            translate('ABCDEFGHIJKLMNOPQRSTUVWXYZ',substring(.,2,1), ''))]
                   [substring(.,3,1) >= 0][9 >= substring(.,3,1)]
                ]/EX

这里是基于XSLT的验证:

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
 <xsl:output omit-xml-declaration="yes" indent="yes"/>

  <xsl:template match="/">
    <xsl:copy-of select=
    "/*/Upload/ContainerEvent
               [WorkAssignmentId
                 [string-length() = 3]
                 [starts-with(., 'F')][substring(.,2,2) >= 0][99 >= substring(.,2,2)]
                ]/EX"/>
==============================
    <xsl:copy-of select=
    "/*/Upload/ContainerEvent
               [WorkAssignmentId
                   [string-length() = 3]
                   [starts-with(., 'F')] 
                   [26 > string-length(
                            translate('ABCDEFGHIJKLMNOPQRSTUVWXYZ',substring(.,2,1), ''))]
                   [substring(.,3,1) >= 0][9 >= substring(.,3,1)]
                ]/EX"/>

  </xsl:template>
</xsl:stylesheet>

当此转换应用于以下XML源文件时 (没有提供)。

<p1>
    <Upload>
        <ContainerEvent>
            <WorkAssignmentId>F13</WorkAssignmentId>
            <EX>F13</EX>
        </ContainerEvent>
        <ContainerEvent>
            <WorkAssignmentId>F99</WorkAssignmentId>
            <EX>F99</EX>
        </ContainerEvent>
        <ContainerEvent>
            <WorkAssignmentId>E15</WorkAssignmentId>
            <EX>E15</EX>
        </ContainerEvent>
        <ContainerEvent>
            <WorkAssignmentId>FA7</WorkAssignmentId>
            <EX>FA7</EX>
        </ContainerEvent>
        <ContainerEvent>
            <WorkAssignmentId>FZ9</WorkAssignmentId>
            <EX>FZ9</EX>
        </ContainerEvent>
        <ContainerEvent>
            <WorkAssignmentId>FAB</WorkAssignmentId>
            <EX>FAB</EX>
        </ContainerEvent>
    </Upload>
</p1>

产生了想要的结果:

<EX>F13</EX>
<EX>F99</EX>
==============================
<EX>FA7</EX>
<EX>FZ9</EX>
© www.soinside.com 2019 - 2024. All rights reserved.