dom4j简单学习
来源:互联网 发布:直销软件定做公司 编辑:程序博客网 时间:2024/05/17 04:52
dom4j帮助文档在dom4j-1.6.1/docs/guide.html文件里面,全部是英文,但是基本上应该能看懂。
1、 四种操作xml的方式:SAX,DOM,JDOM,DOM4J.
2、 DOM(Document Object Model):意思是把整个xml做为一个整体对象,直接全部放到内存里面,不管xml文件有多大;
3、 SAX=Sample API for XML:假如xml文件有2G,用第一种方式,是很困难的,SAX用的是一种类似流媒体方式进行的。
DOM和SAX是java的API,处理xml文件的时候,相对来说是比较困难的,于是出现了下面两种框架,包装了上面两个框架。
4、 JDOM:
5、 DOM4J:
6、 利用DOM4J解析xml文件(读取所有的属性节点)。
Document可以理解为整个文档对象
取root节点。Document.getRootElement()返回的是一个Element(元素)
7、 理解运用xpath,path就是路径,xpath在xml文件里面找到特定的节点。
Document.selectNodes(“//hibernate-mapping/class/property”) //其中hibenate-mapping是根节点。做变org.dom4j.Node对象返回的。
Document.selectSingleNodes(“//hibernate-mapping/class/property”)//只拿第一个。
基中@name是property的属性名valueOf是拿出name的值;
需要加入DOM4J里面的jaxen包
8、 DOM4J的生成xml文件
9、 用FileWriter生成xml文件的时候,可能没有格式,可以用XMLWriter类,这样自动进行美化。
10、 DOM4J修改xml文件;很少用。
11、 自动生成代码往往用的是:freemarker或velocity,这是常用的。用dom4j生成也很少用。
12、 怎么用表里面的结构生成xml文件。
13、 JavaDB
a) Properties对象:可以理解为一个表格对应key,value
14、 Databasemetadata,可以能过这个JDK类,读取数据库的表结构,通过这个表结构做一些自己的事情。(熟悉用法)通过JDK文档和google学习
15、 元数据就是数据的数据,用来描述数据的数据。
16、 DWR,对Ajax框架封住得比较好,是类和java的结合。
dom4j学习实例:
package hb.dom4j;import java.io.FileWriter;import java.io.IOException;import java.util.Iterator;import java.util.List;import org.dom4j.Attribute;import org.dom4j.Document;import org.dom4j.DocumentException;import org.dom4j.DocumentHelper;import org.dom4j.Element;import org.dom4j.Node;import org.dom4j.io.OutputFormat;import org.dom4j.io.SAXReader;import org.dom4j.io.XMLWriter;public class MyJdomReaderXML {public Document parse(String string) throws DocumentException {SAXReader reader = new SAXReader();Document document = reader.read(string);return document;}public void bar(Document document) throws DocumentException {Element root = document.getRootElement();//获得根节点;//进行迭代;读取根节点下的所有节点和子节点下的所有节点for (Iterator i = root.elementIterator(); i.hasNext();) {Element element = (Element) i.next();System.out.println(element.getName());for (Iterator j = element.elementIterator(); j.hasNext();) {System.out.println(((Element) j.next()).getName());}}//读取节点名为foo的所有子节点for (Iterator i = root.elementIterator("foo"); i.hasNext();) {Element foo = (Element) i.next();System.out.println(foo.getName());}//读取根节点的所有属性for (Iterator i = root.attributeIterator(); i.hasNext();) {Attribute attribute = (Attribute) i.next();System.out.println(attribute.getName());}}/* * 可以根据节点名字读取节点,也可以读取节点里的key和value */public void readNodes(Document document) { List list = document.selectNodes( "//foo/bar" ); //foo为根节点,获得根节点下的bar节点 Node node = document.selectSingleNode( "//foo/bar/author" ); //获得名为author的第一 节点 String name = node.valueOf( "@name" ); //获得节点名属性名为name的value }/* * 如果xml文件很大的情况下,用上面的方法很费时,这样 可以用递归遍历整个xml文件 */public void treeWalk(Document document) {treeWalk(document.getRootElement());}/* * 递归调用,传递每一个父节点做为参数 */public void treeWalk(Element element) {for (int i = 0, size = element.nodeCount(); i < size; i++) {Node node = element.node(i);if (node instanceof Element) {//如果node实现了Element接口,那么就表示node是一个节点。再递归treeWalk((Element) node);System.out.println(((Element) node).getName()+":"+node.valueOf("@name"));} else {//如果没有实现Element接口,那么就表示这个node不是节点了,输出节点等操作;}}}//获得节点属性名key为name的valuepublic void findLinks(Document document) throws DocumentException { List list = document.selectNodes( "//ehcache/cache/@name" ); for (Iterator iter = list.iterator(); iter.hasNext(); ) { Attribute attribute = (Attribute) iter.next(); String url = attribute.getValue(); System.out.println(url); } }/* * 创建一个documnet文档 */ public Document createDocument() { Document document = DocumentHelper.createDocument(); Element root = document.addElement( "root" ); Element author1 = root.addElement( "author" ) .addAttribute( "name", "James" ) .addAttribute( "location", "UK" ) .addText( "James Strachan" ); Element author2 = root.addElement( "author" ) .addAttribute( "name", "Bob" ) .addAttribute( "location", "US" ) .addText( "Bob McWhirter" ); return document; } //写入xml文件 public void write(Document document) throws IOException { // lets write to a file XMLWriter writer = new XMLWriter( new FileWriter( "output.xml" ) ); writer.write( document ); writer.close(); // Pretty print the document to System.out OutputFormat format = OutputFormat.createPrettyPrint(); writer = new XMLWriter( System.out, format ); writer.write( document ); // Compact format to System.out format = OutputFormat.createCompactFormat(); writer = new XMLWriter( System.out, format ); writer.write( document ); } /* * 主函数,用来测试 */public static void main(String[] args) throws DocumentException,IOException {MyJdomReaderXML mjrx = new MyJdomReaderXML();Document d = mjrx.parse("test.xml");mjrx.bar(d);System.out.println("------one----------");mjrx.treeWalk(d);System.out.println("------two----------");mjrx.findLinks(d);}}
元素(Element)和结点(Node)有区别,节点包含了元素,元素一定是节点,而必须是含有完整信息的结点才是一个元素。
- dom4j简单学习
- dom4j 的简单学习
- Dom4j解析XML学习之简单解析
- DOM4J学习
- dom4j学习
- 学习:Dom4j
- DOM4J学习
- DOM4J学习
- dom4j简单学习 element和node的区别
- DOM4J学习笔记 --- Java简单解析XML数据
- xml学习笔记—简单使用DOM4J解析xml
- dom4j 简单操作
- dom4j的简单实例
- Dom4j简单案例
- dom4j的简单实例
- dom4j简单使用
- dom4j简单使用
- Dom4j的简单使用
- 实验:min2440LED灯控制
- AAC ADTS LATM 格式分析
- 禁用goto重头再来
- 吉他→左手(卡雷巴洛左手放松技巧)(引用)
- WINCE 串口驱动相关一些函数分析
- dom4j简单学习
- WINCE 编译的时候出现错误 illegal indirection
- C#中StreamReader读取中文文本出现乱码的解决方法
- ITIL V3 学习
- java 执行cmd命令的方式之一(bat)
- 资产的状态-全生命周期
- 对提高箱琴水平很重要的几张专辑和歌曲
- POJ 1976 A Mini Locomotive (动态规划)
- 安全设置MSSQL的具体步骤