import java.io.File;
import java.io.FileWriter;
import java.util.Iterator;
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
public class DOM4JTest {
/** */
/** */
/** */
/**
* DOM4J读写XML示例
*
* @param args
* @throws Exception
*/
public static void main(String[] args) {
try {
XMLWriter writer = null;// 声明写XML的对象
SAXReader reader = new SAXReader();
OutputFormat format = OutputFormat.createPrettyPrint();
format.setEncoding("GBK");// 设置XML文件的编码格式
String filePath = "d:\\student.xml";
File file = new File(filePath);
if (file.exists()) {
Document document = reader.read(file);// 读取XML文件
Element root = document.getRootElement();// 得到根节点
boolean bl = false;
for (Iterator i = root.elementIterator("学生"); i.hasNext();) {
Element student = (Element) i.next();
if (student.attributeValue("sid").equals("001")) {
// 修改学生sid=001的学生信息
student.selectSingleNode("姓名").setText("王五");
student.selectSingleNode("年龄").setText("25");
writer = new XMLWriter(new FileWriter(filePath), format);
writer.write(document);
writer.close();
bl = true;
break;
}
}
if (bl) {
// 添加一个学生信息
Element student = root.addElement("学生");
student.addAttribute("sid", "100");
Element sid = student.addElement("编号");
sid.setText("100");
Element name = student.addElement("姓名");
name.setText("嘎嘎");
Element sex = student.addElement("性别");
sex.setText("男");
Element age = student.addElement("年龄");
age.setText("21");
writer = new XMLWriter(new FileWriter(filePath), format);
writer.write(document);
writer.close();
}
} else {
// 新建student.xml文件并新增内容
Document _document = DocumentHelper.createDocument();
Element _root = _document.addElement("学生信息");
Element _student = _root.addElement("学生");
_student.addAttribute("sid", "001");
Element _id = _student.addElement("编号");
_id.setText("001");
Element _name = _student.addElement("姓名");
_name.setText("灰机");
Element _age = _student.addElement("年龄");
_age.setText("18");
writer = new XMLWriter(new FileWriter(file), format);
writer.write(_document);
writer.close();
}
System.out.println("操作结束! ");
} catch (Exception e) {
e.printStackTrace();
}
}
}
执行结果应该是这样:
循环解析节点:
其次DOM4J的解释
一.Document对象相关
1.读取XML文件,获得document对象.
2.解析XML形式的文本,得到document对象.
3.主动创建document对象.
二.节点相关
1.获取文档的根节点.
2.取得某节点的单个子节点.
3.取得节点的文字
也可以用:
这个是取得根节点下的name字节点的文字.
4.取得某节点下名为"member"的所有字节点并进行遍历.
5.对某节点下的所有子节点进行遍历.
6.在某节点下添加子节点.
7.设置节点文字.
8.删除某节点.
9.添加一个CDATA节点.
三.属性相关.
1.取得某节点下的某属性
2.取得属性的文字
也可以用:
这个是取得根节点下name字节点的属性firstname的值.
3.遍历某节点的所有属性
4.设置某节点的属性和文字.
5.设置属性的文字
6.删除某属性
四.将文档写入XML文件.
1.文档中全为英文,不设置编码,直接写入的形式.
2.文档中含有中文,设置编码格式写入的形式.
评论