xml如何获取节点,标签,属性,文本

xml源文件:

<?xml version="1.0" encoding="utf-8"?>
<contactList>
    <contact id="001" name="aa1" ss="22">
        <name>张三</name>
        <age>20</age>
        <phone>134222223333</phone>
        <email>zhangsan@qq.com</email>
        <qq>432221111</qq>
    </contact>
    <contact id="003">
        <name>lisi</name>
        <age>20</age>
        <phone>134222225555</phone>
        <email>lisi@qq.com</email>
        <qq>432222222</qq>
    </contact>
</contactList>
读取xml文档,返回Document
    SAXReader read = new SAXReader();
    Document doc = read.read(new File("./src/contact.xml"));//返回Document对象

1.获取节点

a.)将获取的节点便利输出:
    Iterator<Node> inter = doc.nodeIterator();//获取节点
    while(inter.hasNext()){//判断是否有下一个元素
            Node node=inter.next();
            String name = node.getName();
            System.out.println(name);//打印出节点名称
    }

节点打印结果

b.)获取该标签节点下的子节点:
if(node instanceof Element){//判断是否有子节点
            Element ele = (Element)node;
            Iterator <Node> ite = ele.nodeIterator();
            while(ite.hasNext()){
                Node nod=ite.next();//打印出子节点名称
                System.out.println(nod.getName());
            }   
}   

子节点打印结果
#####c.)获取所有节点:

    Element ele = dor.getRootElement();//获取根节点
    getChildNode(ele);//调用方法
//获取所有子节点的方法并打印
private void getChildNode(Element elem){
        System.out.println(elem.getName());//输出节点
        Iterator  <Node> it= elem.nodeIterator();
        while(it.hasNext()){
        Node node = it.next();
          if(node instanceof Element){
              Element el = (Element)node;
              getChildNode(el);//递归
          }
         }
}

打印出所有子节点

2.获取标签

a.)先得到根标签:
        Element rootele =doc.getRootElement();//得到根标签
        String name = rootele.getName();
        System.out.println(name);

根标签打印

b.)得到当前标签下的指定名称的子标签:
        Element contele=  rootele.element("contact");//得到当前标签下的指定名称的子标签
        System.out.println(contele.getName());

当前标签下的指定名称的子标签

c.)获得当前标签下指定名称的所有子标签:
 Iterator<Element> it=rootele.elementIterator("contact");//获得当前标签下指定名称的所有子标签
        while(it.hasNext()){
            Element elem = it.next();
            System.out.println(elem.getName());
        }

获得当前标签下指定名称的所有子标签

3.获取属性

a.)先获得属性所在的标签对象:
//获得属性,先获得属性所在的标签对象,然后获取属性
        Element contele =doc.getRootElement().element("contact");
b.)得到指定名称属性值
方法一:
        //得到属性
        //得到指定名称属性值
          String IDValue=  contele.attributeValue("id");
          System.out.println(IDValue);

方法一:得到指定名称属性值

方法二:
//得到指定属性名称的属性对象和属性值
          Attribute attr = contele.attribute("id");
          System.out.println(attr.getName()+"="+attr.getValue());

方法二:得到指定名称属性值

c.)得到指定名称的所有属性值
方法一:
//获取当前标签所有的属性对象和属性值
        List<Attribute> list= contele.attributes();
        for(Attribute arr:list){
            System.out.println(arr.getName()+"="+arr.getValue());
        }  

方法一:获取当前标签所有的属性对象和属性值

方法二:
//获取当前标签所有的属性对象和属性值
Iterator<Attribute> it= contele.attributeIterator();
        while(it.hasNext()){
            Attribute aa= it.next();
            System.out.println(aa.getName()+"="+aa.getValue());
        }

方法二:获取当前标签所有的属性对象和属性值

4.获取文本

a.)先获取文本标签:
//获取文本(先获取文本标点,在获取文本内容)
        Element neamEle = doc.getRootElement().element("contact").element("name");
b.)获取文本内容:
//得到文本内容
        String  nameText = neamEle.getText();
        System.out.println(nameText);

得到文本内容

c.)得到指定标签名的文本内容:
//得到指定标签名的文本内容
        String text2= doc.getRootElement().element("contact").elementText("name");
        System.out.println(text2);

得到指定标签名的文本内容

  • 3
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1.XML 1.1. 概念:XML(eXtensible Markup Language),是一种可扩展的标记语言 1.2. 作用: XML是跨平台和跨语言的 不同的语言都支持XML解析(将XML转换为对应语言中的数据) 1. 数据交换格式(一般不用了,用json代替了) 2. 配置文件都使用XML格式,框架都是用xml和Properties作为配置文件。 1.3. 使用:(掌握) 语法: <?xml version="1.0" encoding="UTF-8"?> <!--注释快捷键:ctrl + shift + / --> <!-- 第一行,必须有。定义XML的版本和字符集 --> <!-- XML中的注释 --> XML的语法格式: 第一行用了定义xml文件的,写版本号和字符集 1.注释不能放到第一行 1.必需有声明,声明必需在第一行。 2.文档声明的字符编码必需和文档本身的编码一致 2.标签不能交叉嵌套使用(标签名字随便定义) 1. 双标签 : <双标签></双标签>一般是有下一级的 2. 单标签 :<单标签/> 如果没有下一级,就可以用单标签 3.有开始有结束 4.不数字开头,只能以字母或下划线开头; 5.只能有一个根标签;表示不能再有其他平级标签 6.严格区分大小写 7.一个标签不能有两个相同属性属性名随便定义) 属性直接写在头标签内,格式:属性名="属性值" 8.特殊符号需要转义 或者可以放到CDATA区 <![CDATA[这里写特殊符号]]> html特殊符号,转义符号 9.编码格式统一: 1.开发环境:项目环境、系统环境 2.当前文件内encoding字符集 10.不能以xml(或者XMLXml等)开头W3C保留日后使用; 例如:最好不要使用 <xml:xx></xml: xx>W3C保留以后在使用 11.名称字符之间不能有空格或者制表符; 例如<四川 省> 12.名称字符之间不能使用冒号;<xml:xx></xml: xx> 注意: 1.Xml中空格和换行都表示数据,严格区分大小写 1.4 XML约束:(了解) 1. 概念:就是限制一个XML文件中标签属性等的使用,只能按照某种规则书写 便于其他程序员学习。 2. 作用: 1. 代码校验 2. 代码提示 3. 利于达成共识形成规范 3. 约束分类: 1. DTD约束:Document Type Definition文档类型定义 例如: <!ELEMENT contacts (linkman+)> <!ELEMENT linkman (name,email,address,group)> <!ELEMENT name (#PCDATA)> <!ELEMENT email (#PCDATA)> <!ELEMENT address (#PCDATA)> <!ELEMENT group (#PCDATA)> 2. schema约束:xml Schema Definition xsd文件 例如: <?xml version="1.0" encoding="UTF-8" ?> <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" targetNamespace="http://itsource.cn" elementFormDefault="qualified"> <xs:element name="contacts"> <xs:complexType> <xs:sequence maxOccurs='unbounded'> <xs:element name="linkman"> <xs:complexType> <xs:sequence> <xs:element name='name' type='xs:string' /> <xs:element name='email' type='xs:string' /> <xs:element name='address' type='xs:string' /> <xs:element name='group' type='xs:string' /> </xs:sequence> <xs:attribute name="id" type="xs:long" use="required"/> </xs:complexType> </xs:element> </xs:sequence> </xs:complexType> </xs:element> </xs:schema> 1.5. XML解析(最重要) DOM: 文档对象模型 将一个XML(html)文档 的每一个元素解析成java中的一个一个的对象 D Document 文档(XML文档) : 磁盘上面的xml文件 O Object 对象(Java对象) : 把xml文件封装成Java对象 M Model 模型 解析过程中用到的类: Document Node(节点) Element (元素) Attribute(属性) - Attr Text(文本) dom4j解析: 支持xpath解析,就可以可以直接输入一个路径查找: 由于DOM4J在解析XML时只能一层一层解析,所以当XML文件层数过多时使用会很不方便, 结合XPATH就可以直接获取到某个元素 使用dom4j支持xpath的操作的几种主要形式   第一种形式     /a/b/c: 表示一层一层的,a下面 b下面的c   第二种形式      //b: 表示和这个名称相同,表示只要名称是b,都得到 第三种形式     /* : 所有元素 第四种形式     a[1]: 表示第一个a元素     a[last()]:表示最后一个a元素 第五种形式     //a[@id]: 表示只要a元素上面有id属性,都得到 第六种形式     //a[@id='b1'] 表示元素名称是a,在a上面有id属性,并且id的属性值是b1 使用dom4j支持xpath具体操作 默认的情况下,dom4j不支持xpath,如果想要在dom4j里面是有xpath, 第一步需要,引入支持xpath的jar包,如下: jaxen-1.1-beta-6.jar 在dom4j里面提供了两个方法,用来支持xpath     selectNodes("xpath表达式"),获取多个节点        selectSingleNode("xpath表达式"),获取一个节点 步骤: 1. 在项目下创建一个lib文件夹folder 2. 复制dom4j的jar包到lib文件夹中 3. 选中jar右键buildpath 4. 在测试类中使用dom4j解析XML。(今天开始学习别人的api) dom4j中使用到的方法: 1.创建SaxReader对象 SAXReader reader = new SAXReader(); 2.设置命名空间 reader.getDocumentFactory().setXPathNamespaceURIs(map); 3. SAXReader对象调用read方法,将当前XML文件,转换为Document对象 document = reader.read(file); 4. 获取节点 root = document.getRootElement(); 5. 通过父签添加子标签元素) Element element = root.addElement("标签名");//返回值就是要添加的元素对象 给子标签添加值 element.setText("标签值"); 6. 给当前标签添加属性:xxx ,值是:xxx Element attribute = linkman.addAttribute("属性名","值"); 通过属性对象attribute获取属性值 attribute.setText("值"); 通过属性对象attribute获取属性值 String 值 = attribute.getText(); 7. 获取当前元素标签名 String name = e.getName(); 获取当前元素标签值 String text = e.getText(); 8. 获取指定名字的子标签元素) root.element(String name); 9. 获取所有子标签元素) root.elements(); 10.在dom4j里面提供了两个方法,用来支持xpath      selectNodes("xpath表达式"),获取当前名字的多个节点 selectSingleNode("xpath表达式"),获取一个节点

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值