XML4
来源:互联网 发布:淘宝ps教程 编辑:程序博客网 时间:2024/04/30 06:21
lDom4j是一个简单、灵活的开放源代码的库。Dom4j是由早期开发JDOM开发的。与JDOM不同的是,dom4j使用接口和抽象的人分离出来而后独立基类,虽然Dom4j的API相对要复杂一些,但它提供了比JDOM更好的灵活性。
lDom4j是一个非常优秀的Java XML API,具有性能优异、功能强大和极易使用的特点。现在很多软件采用的Dom4j,例如Hibernate,包括sun公司自己的JAXM也用了Dom4j。
l使用Dom4j开发,需下载dom4j相应的jar文件。
lDOM4j中,获得Document对象的方式有三种:
1.读取XML文件,获得document对象
SAXReader reader = new SAXReader();
Document document = reader.read(new File("input.xml"));
Document document = reader.read(new File("input.xml"));
2.解析XML形式的文本,得到document对象.
String text = "<members></members>";
Document document = DocumentHelper.parseText(text);
Document document = DocumentHelper.parseText(text);
3.主动创建document对象.
Document document = DocumentHelper.createDocument();
//创建根节点
//创建根节点
Element root = document.addElement("members");
lTip:节点对象
l1.获取文档的根节点.
Element root = document.getRootElement();
l2.取得某个节点的子节点.
Element element=node.element(“书名");
l3.取得节点的文字
String text=node.getText();
l4.取得某节点下所有名为“member”的子节点,并进行遍历.
List nodes = rootElm.elements("member");
for (Iterator it = nodes.iterator(); it.hasNext();) {
Element elm = (Element) it.next();
// do something
}
List nodes = rootElm.elements("member");
for (Iterator it = nodes.iterator(); it.hasNext();) {
Element elm = (Element) it.next();
// do something
}
l5.对某节点下的所有子节点进行遍历.
for(Iterator it=root.elementIterator();it.hasNext();){
Element element = (Element) it.next();
// do something
}
for(Iterator it=root.elementIterator();it.hasNext();){
Element element = (Element) it.next();
// do something
}
l6.在某节点下添加子节点.
Element ageElm = newMemberElm.addElement("age");
Element ageElm = newMemberElm.addElement("age");
l7.设置节点文字.
element.setText("29");
element.setText("29");
l8.删除某节点.
//childElm是待删除的节点,parentElm是其父节点
//childElm是待删除的节点,parentElm是其父节点
parentElm.remove(childElm);
l9.添加一个CDATA节点.
Element contentElm = infoElm.addElement("content");
contentElm.addCDATA(diary.getContent());
Element contentElm = infoElm.addElement("content");
contentElm.addCDATA(diary.getContent());
l节点对象属性
l1.取得某节点下的某属性
Element root=document.getRootElement();
//属性名name
Element root=document.getRootElement();
//属性名name
Attribute attribute=root.attribute("size");
l2.取得属性的文字
String text=attribute.getText();
String text=attribute.getText();
l 3.删除某属性
Attribute attribute=root.attribute("size");
root.remove(attribute);
Attribute attribute=root.attribute("size");
root.remove(attribute);
l3.遍历某节点的所有属性
Element root=document.getRootElement();
for(Iterator it=root.attributeIterator();it.hasNext();){
Attribute attribute = (Attribute) it.next();
String text=attribute.getText();
System.out.println(text);
}
Element root=document.getRootElement();
for(Iterator it=root.attributeIterator();it.hasNext();){
Attribute attribute = (Attribute) it.next();
String text=attribute.getText();
System.out.println(text);
}
l4.设置某节点的属性和文字.
newMemberElm.addAttribute("name", "sitinspring");
newMemberElm.addAttribute("name", "sitinspring");
l5.设置属性的文字
Attribute attribute=root.attribute("name");
attribute.setText("sitinspring");
Attribute attribute=root.attribute("name");
attribute.setText("sitinspring");
l将文档写入XML文件.
l1.文档中全为英文,不设置编码,直接写入的形式.
XMLWriter writer = new XMLWriter(new FileWriter("output.xml"));
writer.write(document);
writer.close();
XMLWriter writer = new XMLWriter(new FileWriter("output.xml"));
writer.write(document);
writer.close();
l2.文档中含有中文,设置编码格式写入的形式.
OutputFormat format = OutputFormat.createPrettyPrint();
// 指定XML编码
OutputFormat format = OutputFormat.createPrettyPrint();
// 指定XML编码
format.setEncoding("GBK");
XMLWriter writer = new XMLWriter(newFileWriter("output.xml"),format);
writer.write(document);
writer.close();
XMLWriter writer = new XMLWriter(newFileWriter("output.xml"),format);
writer.write(document);
writer.close();
lDom4j在指定位置插入节点
l1.得到插入位置的节点列表(list)
l2.调用list.add(index,elemnent),由index决定element的插入位置。
lElement元素可以通过DocumentHelper对象得到。示例代码:
Element aaa = DocumentHelper.createElement("aaa");
aaa.setText("aaa");
List list = root.element("书").elements();
list.add(1, aaa);
//更新document
l字符串与XML的转换
l1.将字符串转化为XML
String text = "<members> <member>sitinspring</member></members>";
Document document = DocumentHelper.parseText(text);
Document document = DocumentHelper.parseText(text);
l2.将文档或节点的XML转化为字符串.
SAXReader reader = new SAXReader();
Document document = reader.read(new File("input.xml"));
Element root=document.getRootElement();
Document document = reader.read(new File("input.xml"));
Element root=document.getRootElement();
String docXmlText=document.asXML();
String rootXmlText=root.asXML();
Element memberElm=root.element("member");
String memberXmlText=memberElm.asXML();
Element memberElm=root.element("member");
String memberXmlText=memberElm.asXML();
- XML4
- XML4
- xml4种解析方式
- JAVA操作XML4种方法的比较
- xml4种解析方法性能比较
- java操作XML4中方法总结(转载)
- ubuntu adb 调试手机
- 关于函数内联及相关关键字inline,__inline,__forceinline的详细说明
- VMware下CentOS5.5安装全过程(图解)
- 如何选择开源项目:开源协议简介
- JavaWeb开发Tomcat-->总结(1)
- XML4
- 网络经济与企业管理
- 10-15
- Windows NT Session 概念的原理与应用浅析 [1] 遍历并获取信息
- 常用开源协议简要介绍
- linux下练习 c++ 序列容器的使用
- Tomcat站点配置
- 批量修改文件名
- 判断两个有序数组中是否存在相同的数字