java-xml文件

java-xml文件使用DOM思想,读取xml文件介绍dom4j核心类1。SAXReaderDOM解析思想的核心类方法:read(绑定了这个xml文件的输入流)读取xml文件返回文档对象,返回值是Doucment对象2.Doucment对象方法:getRootElement()获取文档的根标签返回值:返回的是标签对象Element3.Element标签对象方法获取子标签Listelements()返回所有子标签集合List方法:StringattributeValues(String属性

大家好,又见面了,我是你们的朋友全栈君。

使用DOM思想,读取xml文件
介绍dom4j 核心类
1。SAXReader DOM解析思想的核心类
方法:read(绑定了这个xml文件的输入流) 读取xml文件
返回文档对象,返回值是Doucment对象
2. Doucment对象
方法:getRootElement()获取文档的根标签
返回值:返回的是标签对象Element
3.Element标签对象
方法获取子标签 List elements()
返回所有子标签集合List
方法:String attributeValues(String 属性名) 获取属性值
方法:String getText()获取当前元素的文本内容

xml文件为java工程的配置文件,这样提高了程序的扩展性。代码所需要的外界信息,可直接从xml文件中获取。这样只需要更新xml配置文件即可,不需要对代码进行更改。
再把产品交给客户的时候,并不是直接把写好的代码包拷贝给他,而是把生成的class文件连带着xml文件拷给客户(不会公开源码,客户直接拿到class文件加载到内存进行运行)。
所以xml文件要与源码放在src文件包下面,这样在java生成的out文件夹中,class与xml也放置在一起了。

package xml;

import java.io.InputStream;

public class DOMReaderXml { 
   
    public static void main(String[] args) { 
   
        //使用类加载器,获取输入流,绑定xml文件
        InputStream inputStream = DOMReaderXml.class.getClassLoader().getResourceAsStream("beans.xml");
        
        //核心类,对象
        SAXReader saxreader = new SAXReader();
        //对象sax的read()传递字节流
        Doucment doucment = saxreader.read(inputStream);
        //doucment对象的方法,获取根标签
        Element rootElement = doucment.getRootElement();
        //获取跟标签的两个子标签bean
        List<Element> beanElements = rootElement.elements;
        //先对集合进行判断,然后遍历
        //集合不能是null,集合的长度为0
        if(beanElements != null && beanElements.size()>0){ 
   
            for(Element beanElement : beanElements){ 
   
                //beanElement就是获取的子标签bean
                //获取bean标签的属性id和className
                String id = beanElement.attributeValue("id");
                String className = beanElement.attributeValue("className");
                System.out.println(id + "::" + classNmae);
                //bean标签下还有2个子标签property
                //beanElement bean标签的对象,获取它的子标签
                List<Element> propertyElements = beanElement.elements();
                if(propertyElements != null && propertyElements.size()>0){ 
   
                    for(Element propertyElement : propertyElements){ 
   
                        //propertyElement就是获取的bean的子标签property
                        //property标签的属性name和value
                        String name = propertyElement.attributeValue("name");
                        String value = propertyElement.attributeValue("value");
                        //property标签的文本
                        String text = propertyElement.getText();
                        System.out.println(name + "::" + value + "::" + text);
                    }
                }
            }
        }
    }
}

以上是读取所有的数据,但是我们想能够有效的抓取到真正想要的数据。
XPath能够瞬间定位xml里面我们想要的信息
原生的dom4j不支持XPath
因此采用jaxen-1.1.6.jar结合dom4j-1.6.1.jar使用就可以一起使用了。有效的减少了代码量。

package xml;

import java.io.InputStream;

/** * xpath表达式,快速精确定位xml * 不能单独使用,依靠dom4j(doucment) * * 表达式: * /AAA/DDD/BBB 表示一层一层的 AAA下面 DDD下面的BBB * //BBB 表示和这个名称相同,表示只要名称是BBB 就能得到 * /* 所有元素 * BBB[1] 表示第一个BBB元素 * BBB[last()] 表示最后一个BBB元素 * //BBB[@id] 表示只要BBB元素上面有id属性,就都得到 * //BBB[@id='b1'] 表示元素名称是BBB,在BBB上面有id属性,并且id的属性值是b1 * * List<Node> selectNodes("xpath表达式") 用来获取多个节点 * Node selectSingleNode("xpath表达式") 用来获取一个节点 */
public class XPathReadXml { 
   
    public static void main(String[] args) throws Exception{ 
   
        //类的加载器,获取字节输入流
        InputStream inputStream = XPathReadXml.class.getClassLoader().getResourceAsStream("student.xml");
        //DOM4J的核心对象
        SAXReader saxreader = new SAXReader();
        //read()方法传递字节输入流,返回Doucment对象
        Document doucment = saxreader.read(inputStream);
        //获取根标签
        Element rootElement = doucment.getRoorElement();
        //获取age标签, student/age
        List<Node> list = root.Element.selectNodes("/students/student/age");
        //获取标签sex,xpath最常用的一种形式 //sex
        //返回的是Node节点对象
        //Node node = rootElement.selectSingleNode("//sex");
        Element node = (Element)rootElement.selectSingleNode("//sex");
        System.out.println(node.getText());
        //获取标签是name,属性是id,有这个属性就行
        List<Node> list = rootElement.selectNodes("//name[@id]");
        //获取标签是name,属性是id,有这个属性必须是某个值
        List<Node> list = rootElement.selectNodes("//name[@id='属性值']");
    }
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/156769.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • JAVA设置HttpOnly Cookies

    JAVA设置HttpOnly CookiesHttpOnlyCook 是一个 cookie 安全行的解决方案 在支持 HttpOnlycook 的浏览器中 IE6 FF3 0 如果在 Cookie 中设置了 HttpOnly 属性 那么通过 JavaScript 脚本将无法读取到 Cookie 信息 这样能有效的防止 XSS 攻击 让网站应用更加安全 nbsp 但是 J2EE4 J2EE5 的 Cookie 并没有提供设置 HttpOnly 属性

    2025年7月25日
    3
  • PHP heredoc 用法

    PHP heredoc 用法

    2021年10月31日
    43
  • 拉姆达表达式学习(1)

    拉姆达表达式学习(1)我曾经遇到一个项目,项目里面需要经常对一系列的同类型集合进行操作,如对集合进行增加元素,删除集合的指定索引的元素等等.  我们可以使用ArrayList来进行.如1ArrayListstringList=newArrayList();2stringList.Add(“大家好”);3stringList.Add(“你们好”);4stringList.Add(“同志们…

    2022年9月18日
    3
  • srsLTE测试SDR频偏[通俗易懂]

    srsLTE测试SDR频偏[通俗易懂]1、在Android手机上使用网络信号大师确定当前连接基站的EARFCN。2、修改srsue的ue.conf中earfcn参数为手机连接的基站。3、启动srsue尝试接入,如果收不到基站或接入失败,可以调节ue.conf中的频偏(freq_offset)参数,可以从修改-15000到15000(可以5000为步进调节)不停重复尝试接入。4、能成功接入基站后,FoundCell信息中会有CFO参数,此参数即为频偏,然后再根据此值调试频偏值,频偏=频偏+CFO,比如CFO为-5.5k,频偏=频偏-

    2022年9月27日
    2
  • Scrapy爬虫框架,入门案例(非常详细)「建议收藏」

    Scrapy爬虫框架,入门案例(非常详细)「建议收藏」Scrapy,Python开发的一个快速、高层次的屏幕抓取和web抓取框架,用于抓取web站点并从页面中提取结构化的数据。Scrapy用途广泛,可以用于数据挖掘、监测和自动化测试.其最初是为了页面抓取(更确切来说,网络抓取)所设计的,后台也应用在获取API所返回的数据(例如AmazonAssociatesWebServices)或者通用的网络爬虫.Scrapy吸引人的地…

    2022年6月26日
    28
  • python画图小代码

    python画图小代码奥运五环importturtlet=turtle.Pen()t.speed(1)#画笔颜色为蓝色t.pencolor(“blue”)#画笔宽度为8t.pensize(8)#画半径为60的圆,篮圈t.circle(60)#第一个环t.penup()t.goto(100,0)t.pendown()设置环的颜色t.pencolor(“black”)t.circle(60)#第二个环t.penup()t.goto(200,0)t.pendown()t.pen

    2022年5月17日
    30

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号