栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

JAVA: 解析XML

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

JAVA: 解析XML

  DOM4J解析XML

步骤:

        1:导入dom4j.jar文件包

        2: 创建一个指向XML文件的输入流

 FileInputStream fis = new FileInputStream("xml文件的地址");

        3. 创建一个XML读取工具对象

SAXReader sr = new SAXReader();

        4. 使用读取工具对象, 读取XML文档的输入流 , 并得到文档对象

 document doc = sr.read(fis); 

        5. 通过文档对象, 获取XML文档中的根元素对象

                Element root = doc.getRootElement()

Element root = doc.getRootElement()

    实例:

 //1:获取输入流
        FileInputStream fis=new FileInputStream("I://pingguo.xml");
            //2:创建XML读取对象
        SAXReader sr=new SAXReader();
            //3:读取并得到文档对象
        document doc = sr.read(fis);
            //4:通过文档获取根元素
        Element root = doc.getRootElement();
            //开始解析元素
        System.out.println(root.getName());//获取并打印根节点
        Element ele = root.element("book");//通过element来去查找xml文件中所包含的book
        Element name = ele.element("name");//因为是book的子节点,所以是ele.element("name"),因为是book下的
        //System.out.println(ele.getText());
        //System.out.println(name.getText());
        List emt = root.elements();//先获取里面所有的子元素,然后通过for循环打印出来
        for (int i = 0; i < emt.size(); i++) {
            Element book = emt.get(i);
            System.out.println(book.attributevalue("id"));  //获取属性值,id
            System.out.println(book.elementText("name"));   //获取book里面name的值
            System.out.println(book.elementText("info"));   //获取book里面info的值
        }
        fis.close();
    }
XPATH解析XML

路径表达式:

        1.        /        :表示从根节点开始查找

        2.        //       :表示从指定位置开始查找

        3.        .        :表示从当前节点开始查找

        4.        ..       :表示从父级节点开始查找

        5.        @     :表示选择属性

                                        属性的使用方式:

                                                [@属性名='值']

                                                [@属性名>'值']

                                                [@属性名<'值']

                                                [@属性名!='值']

        books 路径:        //book[@id='1001']//name

        XML文件内容        
                                                
                                                           
                                                                   金苹果
                                                                   锄禾日当午,苹果很辛苦
                                                            

                                                            
                                                                  银苹果
                                                                  锄禾日当午,苹果很辛苦
                                                            

                                                

 使用方法:

        通过Node类的两个方法

      (Node是document和Element的父接口)

        方法1.

                //根据路径表达式, 查找匹配的单个节点

                Element e = selectSingleNode("路径表达式");         

        方法2.     

                 List es = selectNodes("路径表达式");

                案例:

                String phone = "18313935565";

                //1. 获取到XML资源的输入流

                URL url = new URL("http://apis.juhe.cn/mobile/get? phone="+phone+"&dtype=xml&key=9f3923e8f87f1ea50ed4ec8c39cc9253");

                URLConnection conn = url.openConnection();

                 InputStream is = conn.getInputStream();

                 //2. 创建一个XML读取对象

                SAXReader sr = new SAXReader();

                //3. 通过读取对象 读取XML数据,并返回文档对象

                document doc = sr.read(is);

                Node node = doc.selectSingleNode("//company");

                System.out.println("运营商:"+node.getText());

                is.close();

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/343013.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号