android XPath 解析xml

黄舟
Lepaskan: 2017-02-09 13:55:50
asal
2284 orang telah melayarinya

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

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

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

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

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

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(); 

        

           

    }

Salin selepas log masuk

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

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

以上就是 android XPath 解析xml的内容,更多相关内容请关注PHP中文网(www.php.cn)!


Label berkaitan:
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan