Android之使用DOM解析XML文件

1.不推荐只用此方法,使用内存严重,不过对于小文件还是可以使用的

2.DOM(Document Object Model),解析为一棵文档树放在内存中,文档树一般是文档实际大小的几倍,好处只是结构清晰,操作方便

3.实例演示

(1)Person.xml与Person.java见前一篇文章

(2)DOMParser.java

public class DOMPersonParser { public static List<Person> getPersons(InputStream inStream) throws Throwable { //建立一个list集合 List<Person> persons = new ArrayList<Person>(); //获取DocumentBuilderFactory对象实例 DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); DocumentBuilder builder = factory.newDocumentBuilder(); //把需要解析的内容传入解析,这里就已经完成解析了,返回文档树的形式 Document documnet = builder.parse(inStream); //取得文档树的根元素节点 Element root = documnet.getDocumentElement(); //调用Dom API去检索person元素节点 NodeList personNodes = root.getElementsByTagName("person"); for(int i=0 ; i < personNodes.getLength(); i++) { //强制把Person节点的元素转换为Element Element personElement = (Element)personNodes.item(i); // Person person = new Person(); //获取Person节点的id属性 person.setId(new Integer(personElement.getAttribute("id"))); //获取Person的子节点(元素节点与文本节点) NodeList personChilds = personElement.getChildNodes(); for(int y=0 ; y < personChilds.getLength(); y++) { //判断当前节点是否是元素类型节点 if(personChilds.item(y).getNodeType()==Node.ELEMENT_NODE) { //把符合条件的节点强制转换为Element类型 Element childElement = (Element)personChilds.item(y); if("name".equals(childElement.getNodeName())) { //取得元素节点的第一个子节点的文本值 person.setName(childElement.getFirstChild().getNodeValue()); } else if("age".equals(childElement.getNodeName())) { //取得元素节点的第一个子节点的文本值 person.setAge(new Short(childElement.getFirstChild().getNodeValue())); } } } //把当前Person加到集合中 persons.add(person); } return persons; } }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值