DOM4J的遍历某节点属性下的所有文本

//读取xml文件 。
public Document readXML(String filename) {
SAXReader saxReader = new SAXReader();
try {
// 注意:此处用FileInputStream而非FileReader(new
// File(filename)),用UTF8编码保存文件修改后中文乱码的问题
Document doc = saxReader.read(new FileInputStream(filename),"UTF-8");
return doc;
} catch (Exception e) {
e.printStackTrace();
return null;
}
}

//读取root接点。
public Element getRootElement(Document doc){
return doc.getRootElement();
}

//遍历某属性下的所有的值。
public void search(Element root){
//接点迭代
Iterator it_element = root.elementIterator();
while(it_element.hasNext()){
Element element = (Element)it_element.next();
if(!element.getText().equals("")){
System.out.println(element.getName()+"节点的值是"+element.getText());
}else{
System.out.println(element.getName()+"节点");
}
search(element);
}
}


//遍历根节点下的属性。
public void searchRoot(Element root,String content){
//接点迭代
Iterator it_element = root.elementIterator();
while(it_element.hasNext()){
Element element = (Element)it_element.next();
//属性迭代
Iterator it_attr = element.attributeIterator();
while(it_attr.hasNext()){
Attribute attr= (Attribute)it_attr.next();
if(attr != null){
System.out.println(element.getName()+"节点的属性"+attr.getName()+ "的值是" + attr.getValue());
String str = attr.getValue();
if(str.contains(content)){
search(element);
}
}
}
searchRoot(element,content);
}
}

你可能感兴趣的:(dom4j)