dom4j解析XML文件

导入dom4j.jar包

该包需要你去下载。

创建xml文件

XMLWriter writer = null;// 声明写XML的对象

OutputFormat format =

OutputFormat.createPrettyPrint();

format.setEncoding("utf-8");// 设置XML文件的编码格式

String filePath = "F://student.xml";//保存xml文件路径

File file = new File(filePath);

Document _document = DocumentHelper.createDocument();

Element _root = _document.addElement("学生信息");//----------根

Element student = _root.addElement("学生");

Element _id = student.addElement("编号");

_id.setText("001");

Element _name = student.addElement("姓名");

_name.setText("灰机");

Element _age = student.addElement("年龄");

_age.setText("18");

for(int i=0;i<5;i++) {

Element _student = _root.addElement("record");

_student.addAttribute("sid", "00"+i);

_student.addAttribute("phone", "1100"+i);

}

try

{

writer = new XMLWriter(new FileWriter(file), format);

writer.write(_document);

writer.close();

} catch (IOException e) {

e.printStackTrace();

}

System.out.println("操作结束! ");

生成结果图:

读取xml文件

SAXReader reader = new SAXReader();

String filePath = "f://student.xml";

File file = new File(filePath);

Document document;

try {

document = reader.read(file);

Element root = document.getRootElement();// 得到根节点

/*Element database = (Element)root.selectSingleNode("//学生信息/学生");

List list = database.elements(); //得到database元素下的子元素集合

for(Object obj:list){

Element element = (Element)obj;

//getName()是元素名,getText()是元素值

System.out.println(element.getName()+": "+element.getText());

}*/

List nodes = root.elements("学生");

for (Iterator it = nodes.iterator(); it.hasNext();) {

Element elm = (Element) it.next();

for(Iterator it2=elm.elementIterator();it2.hasNext();){

Element elel=(Element)it2.next();

System.out.println(elel.getName()+":"+elel.getText()+":");

}

}

for (Iterator i = root.elementIterator("record"); i.hasNext();) //对所有record子节点进行遍历

{

Element student = (Element) i.next();

//if (student.attributeValue("sid").equals("001")) //如果record属性sid的值等于001

for(Iterator it= student.attributeIterator();it.hasNext();)//获取record节点的所有属性

{

Attribute attribute = (Attribute) it.next();

String name=attribute.getName();//获取属性名

String text=attribute.getText();//获取属性值

System.out.println(name + " :"+text);

}

}

} catch (DocumentException e) {

e.printStackTrace();

}

本篇文档便于可读,所以采用对照式编码格式。

                                                                                         技术分享: www.kaige123.com

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 这个是讲解比较通俗,新手能够很容易理解,在java实现web的功能的时候对XML文件的解析还是比较重要的。 一.D...
    艾衡阅读 305评论 0 2
  • JAXP解析 JAXP的DOM解析 由解析器工厂类获取解析器工厂 解析器工厂产生一个解析器 解析XML,获得一个D...
    老茂在北京阅读 410评论 0 1
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,823评论 18 399
  • 文/任思凡 武汉,22:53―― 『如此幸运』 1.我怎么如此幸运呢,有点受不了老妈这么急忙忙对我这么好,我真的觉...
    任思凡阅读 286评论 0 0
  • 在分析阅读的讲解部分,作者总共列举了他对于分析阅读理解的十五条规则,这些规则在全书的第十一章有一个小的汇总,...
    Holly兔小妖阅读 243评论 0 0