我有一个数组列表,其中包含以下格式的标题和全名
Dr.|ricardo bettati
Prof. Dr.-Ing.|Helmut sperling
miss|angela link
首先我用
|
分割内容。我将获得标题和全名。然后我用空格分割全名以获取firstname
和familyname.
现在我有3弦
字符串标题\,其中包含上面列表中的标题
字符串名字;
字符串姓氏;
下一个任务是我已经使用上述字符串
firstname
和familyname
检查了存在的xml的文本内容。这是存在的xml<person>
<name>
<firstname>Jean-Luc</firstname>
<familyname>DeLorme</familyname>
</name>
</person>
<person>
<name>
<firstname>Dave</firstname>
<familyname>Sperling</familyname>
</name>
</person>
<person>
<name>
<firstname>Helmut</firstname>
<familyname>sperling</familyname>
</name>
</person>
如果
firstname
和familyname
竞争与上述xml元素<firstname>
,<familyname>
的文本内容匹配,那么我必须创建一个名为<title>
的元素并从列表中追加相应的标题。看起来像下面<person>
<name>
<firstname>Jean-Luc</firstname>
<familyname>DeLorme</familyname>
</name>
</person>
<person>
<name>
<firstname>Dave</firstname>
<familyname>Sperling</familyname>
</name>
</person>
<person>
<name>
**<title>Prof. Dr.-Ing.>/title>**
<firstname>Helmut</firstname>
<familyname>sperling</familyname>
</name>
</person>
我尝试了以下代码
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
dbf.setValidating(false);
DocumentBuilder db = dbf.newDocumentBuilder();
Document doc = db.parse(new FileInputStream(new File("Final-Results.xml")));
Element element = doc.getDocumentElement();
NodeList list = doc.getElementsByTagName("person");
for (int i=0;i<titles.size();i++) { //Title is my arraylist
String names = (String) titles.get(i);
String[] content=names.split("\\|");
String title=content[0];
String[] fullname=content[1].split("\\s+");
String firstname=fullname[0];
String familyname=fullname[1];
for (int n = 0; n < list.getLength(); n++) {
Node node = list.item(n);
if ("firstname".equals(node.getNodeName()) && node.getTextContent().equals(firstname)) {
System.out.println("haii");
}
}
}
但是,如何获得孩子并检查文本内容并在特定位置创建节点?
最佳答案
Child node appending: Element childElement = doc.createElement("title"); // set attributes, etc node.appendChild(childElement);
Code can be simplified with xPath, like:
String xPathExpression = "*/person/name[firstname/text() = 'Helmut' and familyname/text() = 'sperling']";
XPath path = XPathFactory.newInstance().newXPath();
NodeList nl = (NodeList) path.evaluate(xPathExpression, doc, XPathConstants.NODESET);
for (int i = 0; i < nl.getLength(); i++) {
Element childElement = doc.createElement("title");
childElement.appendChild(doc.createTextNode("Dr."));
nl.item(i).insertBefore(childElement,((Element)nl.item(i)).getFirstChild());
}
如果在指定的示例上运行代码,则结果为:
<?xml version="1.0" encoding="UTF-8" standalone="no"?><result>
<person>
<name>
<firstname>Jean-Luc</firstname>
<familyname>DeLorme</familyname>
</name>
</person>
<person>
<name>
<firstname>Dave</firstname>
<familyname>Sperling</familyname>
</name>
</person>
<person>
<name><title>Dr.</title>
<firstname>Helmut</firstname>
<familyname>sperling</familyname>
</name>
</person>
</result>