この種のXML文字列を解析したいと思います。
<Objects>
<Object type="crs" obj_id="192">
<Title>Course 1</Title>
<Description>this is description</Description>
<CreateDate>2012-10-16 12:53:12</CreateDate>
<LastUpdate>2012-10-16 12:53:54</LastUpdate>
</Object>
<Object type="frm" obj_id="202">
<Title>Forum 1</Title>
<Description>this is description</Description>
<CreateDate>2012-10-30 01:06:41</CreateDate>
<LastUpdate>2012-10-30 01:06:41</LastUpdate>
</Object>
</Objects>
同じ構造で、ラベルが<Object>のXML文字列を解析しました。次に、ラベルObject内の情報を取得して、type="xxx"の文字列を取得します。
これは私がそれらの種類の解析を行う方法です:
try {
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = dbf.newDocumentBuilder();
InputSource xml = new InputSource();
xml.setCharacterStream(xmlSTring);
Document doc = db.parse(xml);
NodeList nodes = doc.getElementsByTagName("Object");
// iterate objects
for (int i = 0; i < nodes.getLength(); i++) {
Element element = (Element) nodes.item(i);
// get first attribute
NodeList ref_id = element.getElementsByTagName("title");
Element line = (Element) ref_id.item(0);
System.out.println("title: " + getCharacterDataFromElement(line));
}
}
catch (Exception e) {
e.printStackTrace();
}
private static String getCharacterDataFromElement(Element e) {
Node child = e.getFirstChild();
if (child instanceof CharacterData) {
CharacterData cd = (CharacterData) child;
return cd.getData();
}
return "?";
}
前もって感謝します。