利用DOM解析xml文件

除了可以使用 SAX解析XML文件,也可以使用熟悉的DOM来解析XML文件。

DOM解析XML文件时,会将XML文件的所有内容以对象树方式存放在内存中,然后允许您使用DOM API遍历XML树、检索所需的数据。使用DOM操作XML的代码看起来比较直观,并且,在某些方面比基于SAX的实现更加简单。但是,因为DOM需要将XML文件的所有内容以对象树方式存放在内存中,所以内存的消耗比较大,特别对于运行Android的移动设备来说,因为设备的资源比较宝贵,所以建议还是采用SAX来解析XML文件,当然,如果XML文件的内容比较小采用DOM是可行的。

person.xml文件:

<?xml version="1.0" encoding="utf-8"?>
<persons>
    <person id="21">
        <name>hanmeimei</name>
        <age>23</age>
    </person>
    <person id="27">
        <name>lilei</name>
        <age>25</age>
    </person>
</persons>


 

利用DOM解析文件的代码:

/**
 * 利用DOM来解析xml文件
 */
public class DOMPersonService {

	public static List<Person> getPersons( InputStream inStream) throws Exception{
		List<Person> persons = new ArrayList<Person>();
		DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
		DocumentBuilder builder = factory.newDocumentBuilder();
		
		//请注意此处引用的都是import org.w3c.dom.Document;等等
		Document document = builder.parse(inStream);
		Element root = document.getDocumentElement();
		NodeList personNodes = root.getElementsByTagName("person");
		for(int i = 0;i < personNodes.getLength();i++){
			Person person = new Person();
			Element personElement = (Element)personNodes.item(i);
			int id = Integer.parseInt(personElement.getAttribute("id"));
			person.setId(id);
			NodeList childNodes = personElement.getChildNodes();
			for(int j = 0;j < childNodes.getLength();j++){
				Node childNode = childNodes.item(j);
				if(childNode.getNodeType() == Element.ELEMENT_NODE){
					if("name".equals(childNode.getNodeName())){
						//注意此处
						String name = childNode.getFirstChild().getNodeValue();
						person.setName(name);
					}else if("age".equals(childNode.getNodeName())){
						String age = childNode.getFirstChild().getNodeValue();
						person.setAge(new Short(age));
					}
				}
			}
			persons.add(person);
		}
		
		return persons;
	}
}


 

你可能感兴趣的:(利用DOM解析xml文件)