XPath для выбора отдельных значений из файла XML - PullRequest
3 голосов
/ 18 января 2012

У меня есть следующий XML-файл

<people>
<person>
    <name>Diana B. Aust</name>
    <address>8325 Meadow Rd</address>
    <city>Dallas, TX</city>
</person>
<person>
    <name>Diana C. Aust</name>
    <address>8325 Meadow Rd</address>
    <city>Dallas, TX</city>
</person>
<person>
    <name>Acelia T. Peguero</name>
    <address>59 Terry Ave</address>
    <city>Amityville, NY</city>
</person>
<person>
    <name>Acelia U. Peguero</name>
    <address>58 Terry Ave</address>
    <city>Amityville, NY</city>
</person>
</people>

Я хочу выбрать всех лиц на основе уникального адреса + город комбо.Как бы я сделал это с запросом XPath?Правильный запрос должен возвращать узлы № 1, № 3 и № 4.

1 Ответ

1 голос
/ 18 января 2012

Решение XPath 2.0:

/*/person[not(concat(city, address)=preceding-sibling::*/concat(city, address))]

Решение метода Мюнхена XSLT 1.0 (только для справки):

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
    <xsl:output omit-xml-declaration="yes" indent="yes"/>
    <xsl:strip-space elements="*"/>
    <xsl:key name="byAddressAndCity" match="person" 
             use="concat(address, '|', city)"/>
    <xsl:template match="/">
        <xsl:copy-of
            select="*/person[generate-id()=generate-id(
                key('byAddressAndCity', concat(address, '|', city))[1])]"/>
    </xsl:template>
</xsl:stylesheet>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...