传智播客java学习--dom4j解析xml

本文介绍了XML Schema的基本概念,包括约束文档、名称空间及其绑定,并详细展示了使用DOM4J解析XML文档的方法,涉及读取文件、创建文档、节点操作等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天我听了方立勋老师讲的xml基础课程,我做了简单的笔记:

 

xml chema约束

l       XML Schema 文件自身就是一个XML文件,但它的扩展名通常为.xsd。

l       一个XML Schema文档通常称之为模式文档(约束文档),遵循这个文档书写的xml文件称之为实例文档。

l       和XML文件一样,一个XML Schema文档也必须有一个根结点,这个根结点的名称为Schema。

l       编写了一个XML Schema文件后,通常需要把这个文件中声明的元素绑定到一个URI地址上,在XML Schema技术中有一个专业术语来描述这个过程,即把XML Schema文档声明的元素绑定到一个名称空间上,以后XML文件就可以通过这个URI(即名称空间)来告诉解析引擎,xml文档中编写的元素来自哪里,被谁约束。

名称空间的概念

l       在XML Schema中,每个约束模式文档都可以被赋以一个唯一的名称空间,名称空间用一个唯一的URI(Uniform Resource Identifier,统一资源标识符)表示。在Xml文件中书写标签时,可以通过名称空间声明(xmlns),来声明当前编写的标签来自哪个Schema约束文档。如:

       <itcast:书架 xmlns:itcast=“http://www.itcast.cn”>

              <itcast:书>……</itcast:书>

       </itcast:书架>

        此处使用itcast来指向声明的名称,以便于后面对名称空间的引用。

l       注意:名称空间的名字语法容易让人混淆,尽管以 http:// 开始,那个 URL 并不指向一个包含模式定义的文件。事实上,这个 URL:http://www.itcast.cn根本没有指向任何文件,只是一个分配的名字。

 

 

XML解析技术:

l       DOM4J解析XML文档

DOM4j中,获得Document对象的方式有三种:

 

1.读取XML文件,获得document对象            

                   SAXReader reader = new SAXReader();
              Document   document = reader.read(new File("input.xml"));

 

2.解析XML形式的文本,得到document对象.

                   String text = "<members></members>";
              Document document = DocumentHelper.parseText(text);

 

3.主动创建document对象.

                  Document document = DocumentHelper.createDocument();
             //创建根节点

                  Element root = document.addElement("members");

4.取得某节点下名为“member”的子节点并进行遍历.
 List nodes = rootElm.elements("member");
 
  for (Iterator it = nodes.iterator(); it.hasNext();) {
     Element elm = (Element) it.next();
    // do something
 }

 

5.对某节点下的所有子节点进行遍历.
    for(Iterator it=root.elementIterator();it.hasNext();){
       Element element = (Element) it.next();
       // do something
    }

 

6.在某节点下添加子节点.
Element ageElm = newMemberElm.addElement("age");

7.设置节点文字.
 element.setText("29");

 

8.删除某节点.
//childElm是待删除的节点,parentElm是其父节点

    parentElm.remove(childElm);

9.添加一个CDATA节点.
Element contentElm = infoElm.addElement("content");
contentElm.addCDATA(diary.getContent());

 

 

节点对象属性 

1.取得某节点下的某属性
    Element root=document.getRootElement();    
    //属性名name

         Attribute attribute=root.attribute("size");

2.取得属性的文字
    String text=attribute.getText();

 

 3.删除某属性
 Attribute attribute=root.attribute("size");
 root.remove(attribute);

4.遍历某节点的所有属性
   Element root=document.getRootElement();    
   for(Iterator it=root.attributeIterator();it.hasNext();){
         Attribute attribute = (Attribute) it.next();
         String text=attribute.getText();
         System.out.println(text);
    }

 

5.设置某节点的属性和文字.
   newMemberElm.addAttribute("name", "sitinspring");

 

6.设置属性的文字
   Attribute attribute=root.attribute("name");
   attribute.setText("sitinspring");

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值