Получить имя элемента из XML в Java DOM
Я хочу получить имя элемента и распечатать данные в XML, но не знаю, как получить данные под определенным элементом.
Вот пример XML и мой код.
<mdb>
<movies>
<movie id="godfather">
<title>The Godfather</title>
<year>1972</year>
<directors>
<director idref="francisfordcoppola"/>
</directors>
<genres>
<genre>Crime</genre>
<genre>Drama</genre>
</genres>
<cast>
<performer>
<actor idref="marlonbrando"/>
<role>Don Vito Corleone</role>
</performer>
</cast>
</movie>
</movies>
<performer id="kimnovak">
<name>Marilyn Pauline Novak</name>
<dob>1933-02-13</dob>
<pob>Chicago, Illinois, USA</pob>
<actedin>
<movie idref="vertigo"/>
</actedin>
</performer>
</mdb>
try {
File fXmlFile = new File(filename);
DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
Document doc = dBuilder.parse(fXmlFile);
NodeList nodes = doc.getElementsByTagName("movie");
System.out.println("nodes length"+ nodes.getLength());
for (int i = 0; i < nodes.getLength(); i++){
Element element = (Element) nodes.item(i);
NodeList name = element.getElementsByTagName("title");
Element line = (Element) name.item(0);
System.out.println(": " + line.getFirstChild().getTextContent());
Я хочу только получить элемент внутри фильма. но следующий код также читает
<movie idref="vertigo"/>
внутри исполнителя (вызывает исключение Nullpointer, если я хочу получить контент); Мне интересно, есть ли какой-либо возможный способ избежать чтения в разделе "Производительность" с помощью DOM?
NodeList nodes = doc.getElementsByTagName("movie");
Мой окончательный результат для первого фильма должен выглядеть следующим образом:
('godfather', 'The Godfather', '1972', 'Crime;Drama')
Ответы
Ответ 1
Один из способов сделать это - начать чтение из тега movie вместо тега фильма. Не уверен, что это то, что вы ищете!!.
NodeList nodes = doc.getElementsByTagName("movies");
Element element = (Element) nodes.item(0);
NodeList movieList = element.getElementsByTagName("movie");
for (int i = 0; i < movieList.getLength(); i++) {
Element movieElement = (Element) movieList.item(i);
System.out.println(movieElement.getAttributes().getNamedItem("id").getNodeValue());
NodeList name = movieElement.getElementsByTagName("title");
NodeList year = movieElement.getElementsByTagName("year");
NodeList genres = movieElement.getElementsByTagName("genres");
Element genreline = (Element) genres.item(0);
System.out.println(name.item(0).getFirstChild().getTextContent());
System.out.println(year.item(0).getFirstChild().getTextContent());
System.out.println(genreline.getElementsByTagName("genre").item(0).getTextContent()
+ ":" + genreline.getElementsByTagName("genre").item(1).getTextContent());
}
Выход:
: крестный отец
: Крестный отец
: 1972
: Криминальная драма
Ответ 2
Я предлагаю вам прочитать XPath. Вот несколько examples.
Например, чтобы прочитать год для своих фильмов, вы можете использовать XPath...
/mdb/movies/movie/year/text()
Ответ 3
У меня была такая же проблема, это моя реализация,
public String getTagValue(org.w3c.dom.Document xmlDoc, String tagName) throws Exception {
xmlDoc.getDocumentElement().normalize();
NodeList nodeList = xmlDoc.getElementsByTagName(tagName);
for (int temp = 0; temp < nodeList.getLength(); temp++) {
Node nNode = nodeList.item(temp);
if (nNode.getNodeType() == Node.ELEMENT_NODE) {
org.w3c.dom.Element eElement = (org.w3c.dom.Element) nNode;
return eElement.getFirstChild().getNodeValue();
}
}
return "-1";
}