如何在XML ArrayOfString中获取特定字符串?

时间:2016-03-30 05:43:07

标签: xml xpath app-config xpath-2.0 arrayofstring

我有一个由VS生成的配置文件:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <applicationSettings>
    <FMR.OrdersRouter.Service.Properties.Settings>
      <setting name="UseSQL" serializeAs="String">
        <value>True</value>
      </setting>
      <setting name="MaxNumOfConnectionsPerUser" serializeAs="String">
        <value>10</value>
      </setting>
      <setting name="DataPath" serializeAs="String">
        <value>C:\Program Files\Common Files\OrdersRouter</value>
      </setting>
      <setting name="CreditChecks" serializeAs="Xml">
        <value>
          <ArrayOfString xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
            <string>MAXMOFMARGIN:False</string>
            <string>BRSMAXASHRAI:True</string>
            <string>ADDCASH:False</string>
            <string>BUYPOWER:True</string>
          </ArrayOfString>
        </value>
      </setting>
      <setting name="InternalOrdersRouterServerIP" serializeAs="String">
        <value>172.25.2.186</value>
      </setting>
    </FMR.OrdersRouter.Service.Properties.Settings>
  </applicationSettings>
</configuration>

我希望从 ArrayOfString 获取特定字符串。我需要在“MAXMOFMARGIN:”或“BRSMAXASHRAI:”或“ADDCASH:”或“BUYPOWER:”后获得值True / False

我试过了:

substring-after(/configuration/applicationSettings/FMR.OrdersRouter.Service.Properties.Settings/setting[@name="CreditChecks"]/value/ArrayOfString/string, 'BUYPOWER:')

但它仅适用于字符串数组中的第一个字符串。

有什么建议吗?

1 个答案:

答案 0 :(得分:1)

substring-after()需要一个单例参数,所以当你的参数表达式返回多个值时,只会考虑第一个值。假设string值在给定ArrayOfString内始终是唯一的,那么您可以这样做(路径简化只是为了给出一个易于理解的示例):

substring-after(//ArrayOfString/string[contains(.,'BUYPOWER:')], 'BUYPOWER:')

XPath作为substring-after()包含文本string的{​​{1}}元素的第一个参数传递。