1

示例 xml:

<Root>
  <Customers>
    <Customer>
      <CompanyName>Great Lakes Food Market</CompanyName>
      <ContactName>Howard Snyder</ContactName>
      <ContactTitle>Marketing Manager</ContactTitle>
      <Phone>(503) 555-7555</Phone>
      <FullAddress>
        <Address>2732 Baker Blvd.</Address>
        <City>Eugene</City>
        <Region>OR</Region>
        <PostalCode>97403</PostalCode>
        <Country>USA</Country>
      </FullAddress>
    </Customer>
  </Customers>
</Root>

在上面的 xml 中,当我使用“Customer”作为根节点并将 xpath 查询作为“/Root/Customers/Customer”时,我无法打印“FullAddress”的子节点并且当我使用“FullAddress”作为根节点和 xpath 查询为“/Root/Customers/Customer/FullAddress”,无法打印所有字段。

请帮助我解决打印所有 xml 元素的解决方案,包括嵌套在单个报告中。

4

1 回答 1

1

正确的 XPath 查询是

<queryString language="XPath">
    <![CDATA[/Root/Customers/Customer]]>
</queryString>

这包括您的两个节点,要访问值是节点,您应该在定义字段时FullAddress也使用 XPath ,因此可以通过fieldDescriptionAddressFullAddress/Address

例子

如果字段声明CompanyName

<field name="CompanyName" class="java.lang.String">
    <fieldDescription><![CDATA[CompanyName]]></fieldDescription>
</field>

例如Cityis的字段声明

<field name="City" class="java.lang.String">
    <fieldDescription><![CDATA[FullAddress/City]]></fieldDescription>
</field>
于 2017-06-28T15:36:08.593 回答