android XPath 解析xml

互联网 17-2-17

XPath 是一门在 XML 文档中查找信息的语言。XPath 可用来在 XML 文档中对元素和属性进行遍历。

XPath 是 W3C XSLT 标准的主要元素,并且 XQuery 和 XPointer 同时被构建于 XPath 表达之上。

因此,对 XPath 的理解是很多高级 XML 应用的基础。具体学习XPath参照http://www.php.cn/。

XPath只适合用来查询xml的信息,对于完整的解析xml文件的建议不要使用这个方式,最好的解析xml文件应该是sax,pull这两种方式。

我是在android 2.2系统上做的这个测试,低于2.2不知道行不行。

下面就具体说下XPath解析xml的步骤:xpathTest.xml 和android dom 解析xml方式 中的DomTest.xml一样

1、创建InputSources

2、获得XPathFactory实例。

3、用XPathFactory实例获取XPath的实例

4、XPath调用evaluate()方法获取查询出的NodeList

 private void xPathParserXml(){      	//获取XPathFactory实例      	XPathFactory factory = XPathFactory.newInstance();      	//用工程生成XPath实例,解析xml      	XPath xpath = factory.newXPath();      	//  		try {  			InputSource source = new InputSource(getResources().getAssets().open("xPathTest.xml"));  	      			//第一个参数:需要查询的节点名称,必须要在节点前加“//”  	    	//第二个参数:查询的输入源  	    	//第三个参数:返回的类型  //	    	NodeList nodeList = (NodeList) xpath.evaluate("//group", source, XPathConstants.NODESET);  //	    	if(nodeList != null && nodeList.getLength() > 0){  //	    		for(int i = 0;i < nodeList.getLength();i++){  //	    			Node node = nodeList.item(i);  //	    			//在这也可以得到<group>的子节点<person>。但是这样不符合xpath的风格。  //	    			NodeList personList = node.getChildNodes();  //	    			Element  nodeAttr =(Element)node;  //	    			String groupName = nodeAttr.getAttribute("name");  //	    			String num = nodeAttr.getAttribute("num");  //	    			  //	    			Log.e("TEST", ""+groupName+"   "+num);  //	    		}  //	    	}  			  //	    	//获取<person>节点信息  //	    	NodeList personList = (NodeList) xpath.evaluate("//person", source, XPathConstants.NODESET);  //	    	if(personList != null && personList.getLength() > 0){  //	    		for(int i = 0;i < personList.getLength();i++){  //	    			Element node = (Element)personList.item(i);  //	    			//在这也可以得到<person>的子节点<chinese>和<english>。  //	    			NodeList childList = node.getChildNodes();  //	    			String groupName = node.getAttribute("name");  //	    			String age = node.getAttribute("age");  //	    			  //	    			Log.e("TEST", ""+groupName+"   "+age);  //	    		}  //	    	}  	    	  	    	//获取<chinese>节点信息  			NodeList chineseList = (NodeList) xpath.evaluate("//chinese", source, XPathConstants.NODESET);  	    	if(chineseList != null && chineseList.getLength() > 0){  	    		for(int i = 0;i < chineseList.getLength();i++){  	    			Node node = chineseList.item(i);  	    			String chinese = node.getTextContent();  	    			Log.e("TEST", ""+chinese);  	    		}  	    	}  		} catch (IOException e) {  			// TODO Auto-generated catch block  			e.printStackTrace();  		} catch (XPathExpressionException e) {  			e.printStackTrace();  		}      	      }

注意:xpath.evaluate()不能调用两次,报错误。至于原因不清楚。知道原因的请留言告知,谢谢。

对已有人提出XPath能不能查询很大的xml文件(超过1M或),这个在理论上应该可以,只要你能解决InputSource可以读取大容量文件问题就可以了。

来源链接:
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
上一篇:php获取远程图片并下载保存到本地的方法分析 下一篇:小心XmlPullParser.netText()方法

相关资讯