如何用相同的父标记和子标记在Java中解析XML?
考虑以下xml:如何用相同的父标记和子标记在Java中解析XML?,java,xml,xml-parsing,Java,Xml,Xml Parsing,考虑以下xml: <?xml version="1.0"?> <company> <staff id="1001"> <firstname>yong</firstname> <lastname>mook kim</lastname> <nickname>mkyong</nickname> <salary>1
<?xml version="1.0"?>
<company>
<staff id="1001">
<firstname>yong</firstname>
<lastname>mook kim</lastname>
<nickname>mkyong</nickname>
<salary>100000</salary>
</staff>
<staff id="2001">
<firstname>low</firstname>
<lastname>yin fong</lastname>
<nickname>fong fong</nickname>
<salary>200000</salary>
</staff>
</company>
勇
木金
mkyong
100000
低的
尹芳
芳芳
200000
我需要检索XML标记值
File fXmlFile = new File("xmls.xml");
DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
Document doc = dBuilder.parse(fXmlFile);
doc.getDocumentElement().normalize();
System.out.println("Root element :" + doc.getDocumentElement().getNodeName());
NodeList nList = doc.getElementsByTagName("staff");
System.out.println("----------------------------");
for (int temp = 0; temp < nList.getLength(); temp++) {
Node nNode = nList.item(temp);
System.out.println("\nCurrent Element :" + nNode.getNodeName());
if (nNode.getNodeType() == Node.ELEMENT_NODE) {
Element eElement = (Element) nNode;
System.out.println("Staff id : "
+ eElement.getAttribute("id"));
System.out.println("First Name : "
+ eElement.getElementsByTagName("firstname")
.item(0).getTextContent());
System.out.println("Last Name : "
+ eElement.getElementsByTagName("lastname")
.item(0).getTextContent());
System.out.println("Nick Name : "
+ eElement.getElementsByTagName("nickname")
.item(0).getTextContent());
System.out.println("Salary : "
+ eElement.getElementsByTagName("salary")
.item(0).getTextContent()); }}
File fXmlFile=新文件(“xmls.xml”);
DocumentBuilderFactory dbFactory=DocumentBuilderFactory.newInstance();
DocumentBuilder dBuilder=dbFactory.newDocumentBuilder();
documentdoc=dBuilder.parse(fXmlFile);
doc.getDocumentElement().normalize();
System.out.println(“根元素:+doc.getDocumentElement().getNodeName());
NodeList nList=doc.getElementsByTagName(“staff”);
System.out.println(“-------------------------------”;
对于(int-temp=0;temp
当xml中有相同的父节点和子节点时,我需要在代码中创造什么样的机会,如下所示
<?xml version="1.0"?>
<company>
<staff id="1001">
<firstname>yong</firstname>
<lastname>mook kim</lastname>
<nickname>mkyong</nickname>
<salary>100000</salary>
<staff>10</staff>
</staff>
<staff id="2001">
<firstname>low</firstname>
<lastname>yin fong</lastname>
<nickname>fong fong</nickname>
<salary>200000</salary>
</staff>
</company>
勇
木金
mkyong
100000
10
低的
尹芳
芳芳
200000
如果您只关心值,那么就创建Java POJO,用Jackson解析XML。让框架来完成所有的重担
public class Company
{
private Staff[] staff;
public Staff[] getStaff ()
{
return staff;
}
public void setStaff (Staff[] staff)
{
this.staff = staff;
}
@Override
public String toString()
{
return "ClassPojo [staff = "+staff+"]";
}
}
public class Staff
{
private String id;
private String nickname;
private String lastname;
private String firstname;
private String salary;
public String getId ()
{
return id;
}
public void setId (String id)
{
this.id = id;
}
public String getNickname ()
{
return nickname;
}
public void setNickname (String nickname)
{
this.nickname = nickname;
}
public String getLastname ()
{
return lastname;
}
public void setLastname (String lastname)
{
this.lastname = lastname;
}
public String getFirstname ()
{
return firstname;
}
public void setFirstname (String firstname)
{
this.firstname = firstname;
}
public String getSalary ()
{
return salary;
}
public void setSalary (String salary)
{
this.salary = salary;
}
@Override
public String toString()
{
return "ClassPojo [id = "+id+", nickname = "+nickname+", lastname = "+lastname+", firstname = "+firstname+", salary = "+salary+"]";
}
}
然后,您可以使用以下方法填充您的公司
POJO:
Company company = objectMapper.readValue(jsonFileAbove, Company.class);
您可能希望使用:
XPath=XPathFactory.newInstance().newXPath();
节点列表元素=(节点列表)
evaluate(“/company/staff”,doc,XPathConstants.NOESET);
int count=staffElements.getLength();
for(int i=0;i0){
System.out.println(“员工人数:
+staffChildren.item(0.getTextContent());
}
}
XPath xpath = XPathFactory.newInstance().newXPath();
NodeList staffElements = (NodeList)
xpath.evaluate("/company/staff", doc, XPathConstants.NOESET);
int count = staffElements.getLength();
for (int i = 0; i < count; i++) {
Element staffElement = (Element) staffElements.item(i);
System.out.println("Salary : "
+ staffElement.getElementsByTagName("salary")
.item(0).getTextContent());
NodeList staffChildren = + staffElement.getElementsByTagName("staff");
if (staffChildren.getLength() > 0) {
System.out.println("Staff count : "
+ staffChildren.item(0).getTextContent());
}
}