Java采用DOM方式递归遍历XML文件内容

例子中的XML文件内容如下:



	
		冰与火之歌
		乔治马丁
		2014
		89
	
	
		安徒生童话
		2004
		89
		English
	


代码:

package mytest;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;

public class Main {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
		try {
			DocumentBuilder db = dbf.newDocumentBuilder();
			Document book = db.parse("books.xml");
			NodeList root = book.getChildNodes();
			for (int i = 0; i < root.getLength(); i++) 
				read(root.item(i));
		} catch (Exception e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
	
	public static void read(Node node){
		NodeList chileNode = node.getChildNodes();//获取node的字节点
		int length = chileNode.getLength();//获取node字节点的数量
		if(length == 0){//如果node没有字节点
			System.out.print(node.getNodeValue());//输出node中的内容
		}else{									//如果node中有字节点
			System.out.print("<"+node.getNodeName());//输入node的名字
			NamedNodeMap nnm = node.getAttributes();//获取node节点的属性
			if(nnm.getLength() != 0){				//如果它有属性
				for (int i = 0; i < nnm.getLength(); i++) {//遍历它的属性
					Node node2 =  nnm.item(i);			//获取第i个属性
					System.out.print(" "+node2.getNodeName());//输出第i个属性的属性名
					System.out.print("=\""+node2.getNodeValue()+"\"");//输出第i个属性的属性值
				}
			}
			System.out.print(">");
			for (int i = 0; i ");
		}
	}

}


你可能感兴趣的:(Java采用DOM方式递归遍历XML文件内容)