java读写xml文件


要读的xml文件

<?xml version="1.0" encoding="GB2312"?>
<学生花名册>
<学生 性别 = "男">
<姓名>李华</姓名>
<年龄>14</年龄>
</学生>
<学生 性别 = "男">
<姓名>张三</姓名>
<年龄>16</年龄> 
</学生>
</学生花名册>

package xml;

import java.io.FileOutputStream;
import java.io.OutputStreamWriter;
import java.io.Writer;
import java.util.Iterator;
import java.util.Vector;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.transform.OutputKeys;
import javax.xml.transform.Result;
import javax.xml.transform.Source;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerConfigurationException;
import javax.xml.transform.TransformerException;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;

import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.w3c.dom.Text;

public class DomTest {
 Vector students_Vector;

private Vector readXMLFile(String file) throws Exception {
  DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
  DocumentBuilder builder = dbf.newDocumentBuilder();
  Document doc = builder.parse(file); // 获取到xml文件

// 下面开始读取
  Element root = doc.getDocumentElement(); // 获取根元素
  NodeList students = root.getElementsByTagName_r("学生");
  students_Vector = new Vector();
  for (int i = 0; i < students.getLength(); i++) {
   // 一次取得每一个学生元素
   Element ss = (Element) students.item(i);

// 创建一个学生的实例
   student stu = new student();
   stu.setSex(ss.getAttribute("性别"));

NodeList names = ss.getElementsByTagName_r("姓名");
   Element e = (Element) names.item(0);
   Node t = e.getFirstChild();
   stu.setName(t.getNodeValue());

NodeList ages = ss.getElementsByTagName_r("年龄");
   e = (Element) ages.item(0);
   t = e.getFirstChild();
   stu.setAge(Integer.parseInt(t.getNodeValue()));

students_Vector.add(stu);
  }
  return students_Vector;
 }

// 写入xml文件
 public static void callWriteXmlFile(Document doc, Writer w, String encoding) {
  try {
   Source source = new DOMSource(doc);

Result result = new StreamResult(w);

Transformer xformer = TransformerFactory.newInstance()
     .newTransformer();
   xformer.setOutputProperty(OutputKeys.ENCODING, encoding);
   xformer.transform(source, result);

} catch (TransformerConfigurationException e) {
   e.printStackTrace();
  } catch (TransformerException e) {
   e.printStackTrace();
  }
 }

private void writeXMLFile(String outfile) {
  DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
  DocumentBuilder builder = null;
  try {
   builder = dbf.newDocumentBuilder();
  } catch (Exception e) {
  }
  Document doc = builder.newDocument();

Element root = doc.createElement("学生花名册");
  doc.appendChild(root); // 将根元素添加到文档上

// 获取学生信息
  for (int i = 0; i < students_Vector.size(); i++) {
   student s = (student) students_Vector.get(i);
   // 创建一个学生
   Element stu = doc.createElement("学生");
   stu.setAttribute("性别", s.getSex());
   root.appendChild(stu);// 添加属性

// 创建文本姓名节点
   Element name = doc.createElement("姓名");
   stu.appendChild(name);
   Text tname = doc.createTextNode(s.getName());
   name.appendChild(tname);
   
   //创建文本年龄节点
   Element age = doc.createElement("年龄");
   stu.appendChild(age); // 将age添加到学生节点上
   Text tage = doc.createTextNode(String.valueOf(s.getAge()));
   age.appendChild(tage); // 将文本节点放在age节点上
  }
  try {
   FileOutputStream fos = new FileOutputStream(outfile);
   OutputStreamWriter outwriter = new OutputStreamWriter(fos);
   // ((XmlDocument)doc).write(outwriter); //出错!
   callWriteXmlFile(doc, outwriter, "gb2312");
   outwriter.close();
   fos.close();
  } catch (Exception e) {
   e.printStackTrace();
  }
 }

public static void main(String args[]) {
  String str = "xml/student.xml";
  DomTest t = new DomTest();
  try {
   Vector v = t.readXMLFile(str);
   Iterator it = v.iterator();
   while (it.hasNext()) {
    student s = (student) it.next();
    System.out.println(s.getName() + "\t" + s.getAge() + "\t"
      + s.getSex());
   }
  } catch (Exception e) {
   e.printStackTrace();

}

String outfile = "xml/stucopy.xml";
  t.writeXMLFile(outfile);

}
}

class student{
 private String sex;
 private String name;
 private int age;

public int getAge() {
  return age;
 }
 public void setAge(int age) {
  this.age = age;
 }
 public void setSex(String s){sex=s;}
 public String getSex(){return sex;}

public void setName(String n){name=n;}
 public String getName(){return name;}
 }

时间: 2024-10-10 04:30:50

java读写xml文件的相关文章

Java读写xml文件的一些经验(使用dom4j)

说来惭愧,给很多人说过怎么用Java读写xml,但是自己上手做的很少.这篇博客里面简单总结一下. 据网上很多文章介绍,dom4j是一种常用的xml读写API.不过用的时候首先要注意第一个问题:如果在Bing.com里搜索dom4j,排在第一名的是:http://www.dom4j.org/ 很遗憾,这个域名和dom4j没有任何关系,其在Sourceforge上的主页是:http://sourceforge.net/projects/dom4j/ ,我这里下载的是稳定版,将dom4j-1.6.1.

使用dom4j 读写xml文件

dom4j是一个Java的XML API,类似于jdom,用来读写XML文件的.dom4j是一个十分优秀的JavaXML API,具有性能优异.功能强大和极其易使用的特点,同时它也是一个开放源代码的软件. String fileName="D:\\version.xml"; File inputXML=new File(fileName); //使用 SAXReader 解析 XML 文档 version.xml SAXReader saxReader=new SAXReader();

JAXB方式读写XML文件

import java.io.File; import java.util.ArrayList; import java.util.List; import javax.xml.bind.JAXB; import org.apache.log4j.Logger; import org.dom4j.Document; import org.dom4j.Element; import org.dom4j.io.SAXReader; import cn.com.starit.ts.nms.collec

Java读写资源文件类Properties

Java中读写资源文件最重要的类是Properties 1) 资源文件要求如下: 1.properties文件是一个文本文件 2.properties文件的语法有两种,一种是注释,一种属性配置. 注    释:前面加上#号 属性配置:以“键=值”的方式书写一个属性的配置信息. 3.properties文件的一个属性配置信息值可以换行,但键不可以换行.值换行用“\”表示. 4.properties的属性配置键值前后的空格在解析时候会被忽略. 5.properties文件可以只有键而没有值.也可以仅

Java解析XML文件的四种方法

[摘要] 可扩展标志语言(XML)在实现信息标准化.信息的交流与共享上有其独特的技术优势,因此受到了广泛的重视.本文先简单的介绍了XML基本知识,然后从XML应用入手总结了四种现今最常见的XML的解析方法,介绍了这四种方法的特点,其中包括优点与不足之处.最后给出了一个简单的案例来对这四种解析进行代码介绍. [关键字] XML文件,DOM,SAX,JDOM,DOM4J [引言] XML即可扩展标记语言(EXtensible Markup Language),是标准通用标记语言的子集,是一种用于标记

java解析xml文件四种方式介绍、性能比较和基本使用方法

一.介绍: 1)DOM(JAXP Crimson解析器) DOM是用与平台和语言无关的方式表示XML文档的官方W3C标准.DOM是以层次结构组织的节点或信息片断的集合.这个层次结构允许开发人员在树中寻找特定信息.分析该结构通常需要加载整个文档和构造层次结构,然后才能做任何工作.由于它是基于信息层次的,因而DOM被认为是基于树或基于对象的.DOM以及广义的基于树的处理具有几个优点.首先,由于树在内存中是持久的,因此可以修改它以便应用程序能对数据和结构作出更改.它还可以在任何时候在树中上下导航,而不

C#读写xml文件

c#读写xml文件已知有一个XML文件(bookstore.xml)如下: Code<?xml version="1.0" encoding="gb2312"?><bookstore> <book genre="fantasy" ISBN="2-3631-4"> <title>Oberon's Legacy</title> <author>Corets,

java读XML文件

XML文件设计为传输和存储数据,其焦点为数据内容. HTML设计为用来显示数据, 其焦点为数据外观. XML仅仅是文本文件,任何文本编辑器一般情况下都能对其进行编辑. XML没有预定义的标签,并且设定的标签是大小写敏感的. 标签还必须: 必须有根元素 属性值需要加引号 空格等会被保留 必须关闭标签 JAVA读取XML文件 1,language.xml文件内容为: <?xml version="1.0" encoding = "UTF-8" ?> <

iOS 读写xml文件

//*********写入文件,传入要保存的信息*********//保存xml -(void) saveXml:(NSString *)data { //创建文件管理器 NSFileManager *fileManager = [NSFileManager defaultManager ]; //获取路径 //参数NSDocumentDirectory要获取那种路径 NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentD