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進」の属性から他の値を取得するにはどうすればよいですか?
を反復しながら、あなたはまた、属性名を確認することができ
... ... Iこのライブラリを使用する理由があるとは思いますが、XPathとXSLTが素晴らしく、彼ら(特にXPath)が結果をかなり簡単に出力することができます(IMHO) –
I thiこれはSAXやStAXの仕事です。なぜなら、彼はこのXMLのすべての要素とすべてのデータを繰り返し処理しているからです。 – viktor
@Cody S XpathはStaxで使用できません http://stackoverflow.com/questions/1863250/is-it-there-any-xpath-processor-for-sax-model – dusmanka