黑马的小日子--xml解析

xml解析

一:程序设置的技巧--分层设计:

分层设计师用到面向对象的思想,这样做的好处是改动某一层的内容,不影响其它层.

与用户交互的是视图层(View),中间是一些bean和一些Dao(具体操作),底层是数据库层.

二: Jaxp SAX解析xml文档

原理: SAX解析是在读取xml文档内容的同时进行解析,当解析完一个内容就释放掉,然后再读取解析下一个内容,这样就不用加载整个xml文档,节约了内存空间.

SAX解析步骤:

1.通过解析器工厂(SAXParserFactory)创建解析器(SAXParser)实例

SAXParser parser=SAXParserFactory.newInstance().newSAXParser();

2.通过解析器得到读取器(XMLReader)

XMLReader reader=parser.getXMLReader();

3.通过阅读器设置处理器(ConstantHandler);
reader.setConstantHandler(自定义的解析器,这个解析器继承DefaultHandler);
4.读取文档
reader.parser("xml URL");

三:JUnit单元测试

@before 方法加载的时候运行
@after 方法结束的时候运行
@classbefore 类加载时运行
@classafter 类释放时运行
@Test测试方法
测试的方法不能有参数和返回值
断言.

四:Dom4J解析:

解析步骤:

1创建读取器(SAXReader)对象

SAXReader reader=new SAXReader();

2.通过读取器读取xml文档得到Document对象

Document document=reader.read("xml地址");

3.通过document得到根标签

Element root= document.getRootElement();

4.通过根标签进行一些列操作

xPath:相当于正则表达式,用于定位xml中的各个节点


节点对象

1.获取文档的根节点.

      Element root = document.getRootElement();

2.取得某个节点的子节点.

Element element=node.element(“书名");

3.取得节点的文字

      String text=node.getText();

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
    }

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

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

    parentElm.remove(childElm);

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

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

节点对象属性:

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

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

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

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

将文档写入XML文件

1.文档中全为英文,不设置编码,直接写入的形式.
  XMLWriter writer = new XMLWriter(new  FileWriter("output.xml"));
  writer.write(document);
  writer.close();

2.文档中含有中文,设置编码格式写入的形式.
OutputFormat format = OutputFormat.createPrettyPrint();
// 指定XML编码                   

     format.setEncoding("GBK");       
XMLWriter writer = new XMLWriter(new FileOutputStream ("output.xml"),format);
writer.write(document);
writer.close();

Dom4j在指定位置插入节点 

1.得到插入位置的节点列表(list

2.调用list.add(index,elemnent),由index决定element的插入位置。

Element元素可以通过DocumentHelper对象得到。示例代码:

Element aaa = DocumentHelper.createElement("aaa");

aaa.setText("aaa");

List list = root.element("").elements();

list.add(1, aaa);

//更新document


五: Schema:写出头:
1.找到根元素
<?xml version="1.0" encoding="UTF-8"?>
<书架>


</书架>
2.根元素来自哪个命名空间?通过xmlns来设置命名空间,与Schema文档中的targetNamespace
 相对应
<?xml version="1.0" encoding="UTF-8"?>
<heima:书架 xmlns:heima="http://www.itheima.cn">


</heima:书架>
3.这个命名空间又对应哪个xsd文件呢?通过schemaLocation来指定
<?xml version="1.0" encoding="GBK"?>
<heima:书架 xmlns:heima="http://www.itheima.cn"
schemaLocation="http://www.itheima.cn xml的URL">
</heima:书架>
4.schemaLocation有又自哪里呢?
<?xml version="1.0" encoding="gbk"?>
<heima:书架 xmlns:heima="http://www.itheima.cn"
xmlns:xl="http://www.w3.org/2001/XMLSchema-instance"
xl:schemaLocation="http://www.itheima.cn xml的URL">
如果Eclipse没有提示,说明没有找到对应的xsd




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值