利用DOM解析xml文件

来源:互联网 发布:mac取消钥匙串密码 编辑:程序博客网 时间:2024/06/06 00:19

除了可以使用 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;}}