Получаете неправильный вывод в XSLT? - PullRequest
1 голос
/ 06 декабря 2011

Ниже приведен XML-файл -

<Seminars>
  <Seminar>
    <Venue P="ABC" dt="20111223"/>
    <Subject name="Finance">
      <Topic main="Bonds"/>
      <Topic main="Stocks" sub="Technical Analysis"/>
    </Subject>       
  </Seminar>    
  <Seminar>
    <Venue P="ABC" dt="20111225"/>
    <Subject name="Yoga">
      <Topic main="Benefits"/>
    </Subject>
    <Subject name="Meditation">
      <Topic main="Benefits"/>
    </Subject>
  </Seminar>
  <Seminar>
    <Venue P="PQR" dt="20111220"/>       
    <Subject name="IT">
       <Topic main="Java" sub="Swing"/>
       <Topic main="Java" sub="NIO"/>
    </Subject>       
  </Seminar>
  <Seminar>
    <Venue P="ABC" dt="20111224"/>
    <Subject name="Medical">
       <Topic main="Plastic Surgery"/>
       <Topic main="Mal-nutrition"/>
    </Subject>
    <Subject name="IT">
       <Topic main="Java" sub="Collections"/>
       <Topic main="Web Technologies"/>
    </Subject>      
  </Seminar>
  <Seminar>     
    <Venue P="XYZ" dt="20111226"/>
    <Subject name="IT">
      <Topic main="DotNET - I"/>
      <Topic main="DotNET - II"/>
      <Topic main="XML" sub="Security"/>
    </Subject>       
  </Seminar>
  <Seminar>
     <Venue P="XYZ" dt="20111227"/>
     <Subject name="IT">
        <Topic main="Oracle"/>
        <Topic main="Oracle" sub="JDeveloper"/>
     </Subject>       
  </Seminar>
</Seminars>

Ниже приведена программа Java -

import org.w3c.dom.*;
import javax.xml.xpath.*;
import javax.xml.parsers.*;
import java.io.IOException;
import org.xml.sax.SAXException;

public class Seminar
{
   public static void main(String[] args) throws ParserConfigurationException, SAXException, IOException, XPathExpressionException 
   {
      DocumentBuilderFactory domFactory = DocumentBuilderFactory.newInstance();
      domFactory.setNamespaceAware(true); 
      DocumentBuilder builder = domFactory.newDocumentBuilder();
      Document doc = builder.parse("seminar.xml");
      XPath xpath = XPathFactory.newInstance().newXPath();

      String qry = "//Seminars/Seminar[contains(Subject/@name,'Medical')]/Subject/Topic/@main";
      XPathExpression expr = xpath.compile(qry);
      Object result = expr.evaluate(doc, XPathConstants.NODESET);
      NodeList nodes = (NodeList) result;

      for (int i = 0; i < nodes.getLength(); i++) 
      {
           System.out.println(nodes.item(i).getNodeValue());
      }
   }
}

При использовании вышеуказанной программы я ожидал вывод в виде -

Plastic Surgery
Mal-nutrition

Но я также получаю вывод для следующего тега Subject, значение атрибута которого равно IT ... ???

Чего мне не хватает в запросе ...

Ответы [ 2 ]

3 голосов
/ 06 декабря 2011

Ваш запрос должен быть

  String qry = "//Seminars/Seminar/Subject[contains(@name,'Medical')]/Topic/@main";

Вы запрашивали все темы в Seminar, содержащие Subject с "Медицинским" в @name.Новый запрос запрашивает все Topics в Subject, которое содержит «Medical» в @name.Тонкое, но важное отличие!

2 голосов
/ 06 декабря 2011

Ваш XPath выдаст вам всю тему / тему [@main] для любого семинара, в котором есть хотя бы один субъект с именем Medical .

Вы, вероятно, хотите

String qry = "//Seminars/Seminar/Subject[contains(@name,'Medical')]/Topic/@main";

или

String qry = "//Seminars/Seminar/Subject[@name='Medical']/Topic/@main";
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...