XML 作为全球通用的结构化语言,越来越受人们青睐,各种开发平台(比如 Microsoft Studio系列、Oracle 系列、Inprise Borland 系列等)也都把支持 XML 开发作为宣传口号之一。在许多项目中利用 XML 数据交换信息,省去了许多麻烦事,不用制定繁锁的数据格式,利用 XML 数据易于表达,
也利于一线开发者跟踪调试。
在 XML 应用中,最常用也最实用的莫过于 XML 文件的读写,所以笔者通过一个简单的 XML 文件读写来作简要分析。可以在任何文本编辑器中先建立如下结构的 XML 文件,类似于 HTML 结构,但 XML 语义比较严格,起始标记必须配对,比如"〈学生花名册〉"与"〈/学生花名册〉"对应,空格
多少可不必在意,但一般都以缩格形式书写,便于阅读。把此文件命名为 Input.xml,可以在任何支持 XML 的浏览器中打开测试一下,如果输入确,在浏览中可以看到此文件的树形表示结构。如果
您还对 XML 结构感到比较陌生,建议先看看《简析 Delphi 中的 XML 编程》一文中关于 XML 文件的说明。
<?xml version="1.0" encoding="GB2312"?> <学生花名册> <学生 性别 = "男"> <姓名>李华</姓名> <年龄>14</年龄> <电话>6287555</电话> </学生> <学生 性别 = "男"> <姓名>张三</姓名> <年龄>16</年龄> <电话>8273425</电话> </学生> </学生花名册>
准备工作做完后,接着就开始写实质性的 JAVA 代码了。为保存从 XML 文件读入的信息,需要
先建一个简单的 Bean 来保存学生信息,命名为 StudentBean,代码如下所示:
public class StudentBean { private String sex; //学生性别 private String name; //学生姓名 private int age; //学生年龄 private String phone; //电话号码 public void setSex(String s) { sex = s; } public void setName(String s) { name = s; } public void setAge(int a) { age = a; } public void setPhone(String s) { phone = s; } public String getSex() { return sex; } public String getName() { return name; } public int getAge() { return age; } public String getPhone() { return phone; } }
之后写 XML 的测试类,笔者把这个类命名为 XMLTest,为了读写 XML 文件,需要导入如下 JAVA包,"//"后为注释说明,笔者的环境是 JDK 1.3.1_04,在 JDK 1.4.0 中测试也通过,XML 解释器用 Apache的 Crimson,可以到 Apache 主页去上载。
import java.io.*; //Java 基础包,包含各种 IO 操作 import java.util.*; //Java 基础包,包含各种标准数据结构操作 import javax.xml.parsers.*; //XML 解析器接口 import org.w3c.dom.*; //XML 的 DOM 实现 import org.apache.crimson.tree.XmlDocument; //写 XML 文件要用到
为了保存多个学生信息,还得借助一个集合类(并不是单纯意义上的集合,JAVA 中的集合是集合框架的概念,包含向量、列表、哈希表等),这里采用 Vector 向量类。定义在 XMLTest 测试类中,命名为 student_Vector。然后定义两个方法 readXMLFile 和 writeXMLFile,实现读写操作。代码如下:
private void readXMLFile(String inFile) throws Exception { //为解析 XML 作准备 //创建 DocumentBuilderFactory 实例,指定 DocumentBuilder DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance(); DocumentBuilder db = null; try { db = dbf.newDocumentBuilder(); } catch (ParserConfigurationException pce) { System.err.println(pce); //出异常时输出异常信息,然后退出,下同 System.exit(1); } Document doc = null; try { doc = db.parse(inFile); } catch (DOMException dom) { System.err.println(dom.getMessage()); System.exit(1); } catch (IOException ioe) { System.err.println(ioe); System.exit(1); } //下面是解析 XML 的全过程, //比较简单,先取根元素"学生花名册"Element root = doc.getDocumentElement(); //取"学生"元素列表 NodeList students = root.getElementsByTagName("学生"); for (int i = 0; i < students.getLength(); i++) { //依次取每个"学生"元素 Element student = (Element) students.item(i); //创建一个学生的 Bean 实例 StudentBean studentBean = new StudentBean(); //取学生的性别属性 studentBean.setSex(student.getAttribute("性别")); //取"姓名"元素,下面类同 NodeList names = student.getElementsByTagName("姓名"); if (names.getLength() == 1) { Element e = (Element) names.item(0); Text t = (Text) e.getFirstChild(); studentBean.setName(t.getNodeValue()); }NodeList ages = student.getElementsByTagName("年龄"); if (ages.getLength() == 1) { Element e = (Element) ages.item(0); Text t = (Text) e.getFirstChild(); studentBean.setAge(Integer.parseInt(t.getNodeValue())); } NodeList phones = student.getElementsByTagName("电话"); if (phones.getLength() == 1) { Element e = (Element) phones.item(0); Text t = (Text) e.getFirstChild(); studentBean.setPhone(t.getNodeValue()); }student_Vector.add(studentBean); } } private void writeXMLFile(String outFile) throws Exception { //为解析 XML 作准备, //创建 DocumentBuilderFactory 实例,指定 DocumentBuilder DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance(); DocumentBuilder db = null; try { db = dbf.newDocumentBuilder(); } catch (ParserConfigurationException pce) { System.err.println(pce); System.exit(1); } Document doc = null; doc = db.newDocument();//下面是建立 XML 文档内容的过程,//先建立根元素"学生花名册" Element root = doc.createElement("学生花名册"); //根元素添加上文档 doc.appendChild(root);//取学生信息的 Bean 列表 for (int i = 0; i < student_Vector.size(); i++) { //依次取每个学生的信息 StudentBean studentBean = (StudentBean) student_Vector.get(i); //建立"学生"元素,添加到根元素 Element student = doc.createElement("学生"); student.setAttribute("性别", studentBean.getSex()); root.appendChild(student); //建立"姓名"元素,添加到学生下面,下同 Element name = doc.createElement("姓名"); student.appendChild(name); Text tName = doc.createTextNode(studentBean.getName()); name.appendChild(tName);Element age = doc.createElement("年龄"); student.appendChild(age); Text tAge = doc.createTextNode(String.valueOf(studentBean.getAge())); age.appendChild(tAge);Element phone = doc.createElement("电话"); student.appendChild(phone); Text tPhone = doc.createTextNode(studentBean.getPhone()); phone.appendChild(tPhone); } //把 XML 文档输出到指定的文件 FileOutputStream outStream = new FileOutputStream(outFile); OutputStreamWriter outWriter = new OutputStreamWriter(outStream); ((XmlDocument) doc).write(outWriter, "GB2312"); outWriter.close(); outStream.close(); }
最后加入测试主函数,如下:
public static void main(String[] args) throws Exception { //建立测试实例 XMLTest xmlTest = new XMLTest(); //初始化向量列表 xmlTest.student_Vector = new Vector();System.out.println("开始读 Input.xml 文件"); xmlTest.readXMLFile("Input.xml");System.out.println("读入完毕,开始写 Output.xml 文件"); xmlTest.writeXMLFile("Output.xml"); System.out.println("写入完成"); }
好了,保存好 StudentBean 和 XMLTest,把 Input.xml 保存到工作目录下。可以看到"写入完成"了。
【下载地址】
百度网盘链接:https://pan.baidu.com/s/17upS29XuXVtM6oUSKmt-DQ
提取码:z968
相关文章
使用-JFreeChart来创建基于web的图表
XStream使用文档
WebService发布过程及常见问题
webpack实战入门进阶调优分享
weblogic调优参数及监控指标
weblogic节点管理
weblogic管理控制台概述
weblogic-部署和启动
WebLogic-Server-性能及调优-调优-Java-虚拟机
Java 虚拟机(Java virtual machine,简称 JVM)是一种虚拟“执行引擎”实例,可在微处理器上执行 Java 类文件中的字节码。调整 JVM 的方式会影响 Weblogic Server 和应用程序的性能。
Velocity是一个基于java的模板引擎(template engine)。它允许任何人仅仅简单的使用模板语言(template language)来引用由java代码定义的对象。
Velocity 用户手册是帮助页面设计者和内容提供者认识 Velocity 和其简单而功能强大的脚本语言――Velocity 模板语言(VTL)。在手册上的许多例子,都是用 Velocity 插入动态的内容到网页上,但是所有的 VLT 例子都能应用到其他的页面和模板中。
FlashFXP绿色版网盘下载,附激活教程 1778
FlashFxp百度网盘下载链接:https://pan.baidu.com/s/1MBQ5gkZY1TCFY8A7fnZCfQ。FlashFxp是功能强大的FTP工具
Adobe Fireworks CS6 Ansifa绿色精简版网盘下载 1564
firework可以制作精美或是可以闪瞎眼的gif,这在广告领域是需要常用的,还有firework制作下logo,一些原创的图片还是很便捷的,而且fireworks用法简单,配合dw在做网站这一块往往会发挥出很强大的效果。百度网盘下载链接:https://pan.baidu.com/s/1fzIZszfy8VX6VzQBM_bdZQ
navicat for mysql中文绿色版网盘下载 1623
Navicat for Mysql是用于Mysql数据库管理的一款图形化管理软件,非常的便捷和好用,可以方便的增删改查数据库、数据表、字段、支持mysql命令,视图等等。百度网盘下载链接:https://pan.baidu.com/s/1T_tlgxzdQLtDr9TzptoWQw 提取码:y2yq
火车头采集器(旗舰版)绿色版网盘下载 1706
火车头采集器是站长常用的工具,相比于八爪鱼,简洁好用,易于配置。火车头能够轻松的抓取网页内容,并通过自带的工具对内容进行处理。站长圈想要做网站,火车头采集器是必不可少的。百度网盘链接:https://pan.baidu.com/s/1u8wUqS901HgOmucMBBOvEA
Photoshop(CS-2015-2023)绿色中文版软件下载 1822
安装文件清单(共46G)包含Window和Mac OS各个版本的安装包,从cs到cc,从绿色版到破解版,从安装文件激活工具,应有尽有,一次性打包。 Photoshop CC绿色精简版 Photoshop CS6 Mac版 Photoshop CC 2015 32位 Photoshop CC 2015 64位 Photoshop CC 2015 MAC版 Photoshop CC 2017 64位 Adobe Photoshop CC 2018 Adobe_Photoshop_CC_2018 Photoshop CC 2018 Win32 Photoshop CC 2018 Win64