XPath: выбор текстового узла
имея следующий XML:
<node>Text1<subnode/>text2</node>
Как выбрать первый или второй текстовый узел через XPath?
что-то вроде этого:
/node/text()[2]
конечно, не работает, потому что это объединенный результат каждого текста внутри узла.
2 ответов
имея следующий XML:
<node>Text1<subnode/>text2</node>
Как выбрать первый или второй текстовый узел через XPath?
использовать:
/node/text()
это выбирает все дочерние текстовые узлы верхнего элемента (с именем "узел") XML-документа.
/node/text()[1]
это выбирает первый дочерний текстовый узел верхнего элемента (с именем "узел") XML-документа.
/node/text()[2]
это выбирает второй текстовый узел дочерний элемент верхнего элемента (с именем "узел") XML-документа.
/node/text()[someInteger]
это выбирает someinteger-й текстовый узел дочернего элемента верхнего элемента (с именем "узел") XML-документа. Это эквивалентно следующему выражению XPath:
/node/text()[position() = someInteger]
ваш xpath должен работать . я протестировал ваш xpath и мой в реализации MarkLogic и Zorba Xquery / Xpath.
как должно работать.
/node/child::text()[1] - should return Text1
/node/child::text()[2] - should return text2
/node/text()[1] - should return Text1
/node/text()[2] - should return text2