2011-12-14 11 views
2

STAXを使用してURIからXMLファイルを解析しようとしました!staxが要素からatribute値を取得する

<Type type_id="4218"> 
     <Title>English Premier League</Title> 

     <Event start_time="2011-12-18 16:10:00" ev_id="2893772"> 
       <Description>Manchester City v Arsenal</Description> 

        <Market mkt_typ="Win/Draw/Win"> 
         <Occurrence bet_id="42455761" decimal="1.6666666666667"> 
           <Description>Manchester City</Description> 
         </Occurrence> 
         <Occurrence bet_id="42455762" decimal="3.6"> 
           <Description>Draw</Description> 
         </Occurrence> 
         <Occurrence bet_id="42455764" decimal="5"> 
          <Description>Arsenal</Description> 
          </Occurrence> 
        </Market> 

      </Event> 
    </Type> 

出力は次のようになります:

XMLInputFactory factory = XMLInputFactory.newInstance(); 

     try { 
      XMLStreamReader streamReader = factory.createXMLStreamReader(new URL("http://cubs.bluesq.com/cubs/cubs.php?action=getpage&thepage=385.xml").openStream()); 


      while (streamReader.hasNext()) { 
       int event = streamReader.next(); 

       if(event == XMLStreamConstants.START_ELEMENT){ 
        if(streamReader.getLocalName().equals("Type")){ 
         long id = Integer.parseInt(streamReader.getAttributeValue(null, "type_id")); 
         if(id == 4218){ 
          System.out.println("id:"+id); 
          streamReader.nextTag(); 
          System.out.println("title:"+streamReader.getElementText()); 
          streamReader.nextTag(); 
          int ev_id = Integer.parseInt(streamReader.getAttributeValue(null, "ev_id")); 
          System.out.println("ev_id:"+ev_id); 
          DateFormat formater = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss"); 
          formater.setTimeZone(TimeZone.getTimeZone("CET")); 
          String tempDatum = streamReader.getAttributeValue(null,"start_time"); 
          Date dateOfMatch = formater.parse(tempDatum); 

          System.out.println("date of match:"+dateOfMatch); 
          streamReader.nextTag(); 
          String description = streamReader.getElementText(); 

          System.out.println("description:"+ description); 
          streamReader.nextTag(); 
          String market = streamReader.getAttributeValue(null, "mkt_typ"); 
          if(market.equals("Win/Draw/Win")){ 
           streamReader.nextTag(); 
            double one = Double.parseDouble(streamReader.getAttributeValue(null, "decimal")); 
            System.out.println("one:"+ one); 

            double draw = Double.parseDouble(streamReader.getAttributeValue(null, "decimal")); 
            System.out.println("draw:"+draw); 
            double two = Double.parseDouble(streamReader.getAttributeValue(null, "decimal")); 
            System.out.println("two:"+two); 

          } 


         } 
        } 
       } 

      } 

このコード農産物出力:

id:4218 
title:English Premier League 
ev_id:2893772 
date of match:Sun Dec 18 16:10:00 CET 2011 
description:Manchester City v Arsenal 
one:1.6666666666667 
draw:3.6 
two:5 

私のコードは次のようになりますこのような何かを探して

XML

id:4218 
title:English Premier League 
ev_id:2893772 
date of match:Sun Dec 18 16:10:00 CET 2011 
description:Manchester City v Arsenal 
one:1.6666666666667 
draw:1.6666666666667 
two:1.6666666666667 

「出現」の要素で「10進」の属性から他の値を取得するにはどうすればよいですか?

+0

を反復しながら、あなたはまた、属性名を確認することができ

 while (xmlEventReader.hasNext()) { XMLEvent event = xmlEventReader.nextEvent(); if (event.isStartElement()) { StartElement startElement = event.asStartElement(); QName qname = startElement.getName(); String elementName = qname.toString(); if (elementName.equals("My Element")) { Iterator attributes = startElement.getAttributes(); while (attributes.hasNext()) { Attribute attribute = (javax.xml.stream.events.Attribute) (attributes.next()); String attribute= attribute.getValue(); desiredAttribute = attribute; } 

... ... Iこのライブラリを使用する理由があるとは思いますが、XPathとXSLTが素晴らしく、彼ら(特にXPath)が結果をかなり簡単に出力することができます(IMHO) –

+0

I thiこれはSAXやStAXの仕事です。なぜなら、彼はこのXMLのすべての要素とすべてのデータを繰り返し処理しているからです。 – viktor

+0

@Cody S XpathはStaxで使用できません http://stackoverflow.com/questions/1863250/is-it-there-any-xpath-processor-for-sax-model – dusmanka

答えて

2

if(market.equals("Win/Draw/Win")){ streamReader.nextTag();

私は簡単に見ていたが、私は、あなたはおそらく、あなたがstreamReader.nextTagを呼び出しているので、一回のみ)(最初に検出された要素に滞在しますが、streamReader.getAttributeValueされていると言うでしょう3回。

0

プライベート文字列xmlFile = "ファイルの場所"; プライベート文字列desiredAttribute;

...

のClassLoaderクラスローダ= this.getClass()のgetClassLoader()。

XMLInputFactory inputFactory = XMLInputFactory.newInstance(); 
    InputStream inputStream = classLoader.getResourceAsStream(xmlFile); 
    XMLEventReader xmlEventReader = inputFactory.createXMLEventReader(inputStream); 

試し{これは、XSLTおよび/またはXPathのための仕事のように見えます