- 浏览: 122041 次
- 性别:
- 来自: 南宁
文章分类
最新评论
我是要把一个JAVABEAN写入一个XML中,然后再度出,我是利用了一个vector,先把所有要读入的同一个StudentBean都添加到一个vector中我的StudentBean如下:
import java.io.Serializable;
public class StudentBean implements Serializable
{
String name;
String sex;
String phone;
public StudentBean(String name, String sex, String phone) {
super();
this.name = name;
this.sex = sex;
this.phone = phone;
}
public StudentBean()
{};
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public String getPhone() {
return phone;
}
public void setPhone(String phone) {
this.phone = phone;
}
}
写操作是如下:
import org.w3c.dom.*;
import javax.xml.parsers.*;
import javax.xml.transform.*;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import java.io.*;
import java.util.Vector;
public class writexml {
private Document document;
private String filename;
public writexml(String name) throws ParserConfigurationException{
filename=name;
DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance();
DocumentBuilder builder=factory.newDocumentBuilder();
document=builder.newDocument();
}
public void toWrite(Vector<StudentBean> stu_vector)
{
Element root = document.createElement("seller_record");
document.appendChild(root);
for(int i = 0;i<stu_vector.size();i++)
{
StudentBean stu = (StudentBean) stu_vector.get(i);
Element student = document.createElement("student");
student.setAttribute("name",stu.name);
root.appendChild(student);
Element sex = document.createElement("sex");
student.appendChild(sex);
Text tsex = document.createTextNode(stu.sex);
sex.appendChild(tsex);
Element phone = document.createElement("phone");
student.appendChild(phone);
Text tphone = document.createTextNode(stu.phone);
phone.appendChild(tphone);
}
}
public void toSave(){
try{
TransformerFactory tf=TransformerFactory.newInstance();
Transformer transformer=tf.newTransformer();
DOMSource source=new DOMSource(document);
transformer.setOutputProperty(OutputKeys.ENCODING,"GB2312");
transformer.setOutputProperty(OutputKeys.INDENT,"yes");
PrintWriter pw=new PrintWriter(new FileOutputStream(filename));
StreamResult result=new StreamResult(pw);
transformer.transform(source,result);
}
catch(TransformerException mye){
mye.printStackTrace();
}
catch(IOException exp){
exp.printStackTrace();
}
}
public static void main(String args[]){
Vector<StudentBean> stu_vector = new Vector<StudentBean>();
StudentBean stu = new StudentBean("姚明","男","123456");
stu_vector.add(stu);
stu = new StudentBean("刘翔","女","0988556");
stu_vector.add(stu);
try{
writexml myxml=new writexml("E:\\软件\\eclipse\\workstation\\IOxml\\src\\seller.xml");
myxml.toWrite(stu_vector);
myxml.toSave();
System.out.print("Your writing is successful.");
}
catch(ParserConfigurationException exp){
exp.printStackTrace();
System.out.print("Your writing is failed.");
}
}
}
下面是读操作:
import java.io.*;
import java.util.Vector;
import javax.xml.parsers.*;
import org.w3c.dom.*;
public class readxml {
static Document document;
private boolean validating;
public readxml() {
}
public Vector<StudentBean> toRead(String filename)
{
Vector<StudentBean> stu_vector=new Vector<StudentBean>();
StudentBean stu = new StudentBean();
try {
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
factory.setIgnoringElementContentWhitespace(true);
factory.setValidating(validating);
DocumentBuilder builder = factory.newDocumentBuilder();
document = builder.parse(new File(filename));
// document.getDocumentElement().normalize();//注释(0)
Element root = document.getDocumentElement();
NamedNodeMap attr;
NodeList children = root.getElementsByTagName("student");//注释(1)
attr = root.getAttributes();
if(attr!=null)
{
for(int i = 0;i<children.getLength();i++)
{
Element element= (Element) children.item(i);
stu.setName(element.getAttribute("name"));
NodeList list = element.getChildNodes();
System.out.println(list.getLength());
Node child = list.item(i);
System.out.println(element.getAttribute("name"));
System.out.println(list.item(1).getTextContent());//注释(2)
System.out.println(list.item(3).getTextContent());//注释(3)
stu.setName(element.getAttribute("name"));
stu.setSex(list.item(1).getTextContent());
stu.setPhone(list.item(3).getTextContent());
stu_vector.add(stu);
}
}
}
catch (Exception exp)
{
exp.printStackTrace();
return null;
}
return stu_vector;
}
public static void main(String[] args) {
Vector<StudentBean> A = null;
readxml my = new readxml();
A = my.toRead("E:\\软件\\eclipse\\workstation\\IOxml\\src\\seller.xml");
System.out.println(A.size());
System.out.println("asd");
}
}
在下面是我读入的XML格式如下:
<seller_record>
−
<student name="姚明">
<sex>男</sex>
<phone>123456</phone>
</student>
−
<student name="刘翔">
<sex>女</sex>
<phone>0988556</phone>
</student>
</seller_record>
我写入的XML文档根有两个孩子,两个孩子又有3个node;
下面简要谈一下我对读操作的理解(主要是我标的注释的地方):
注释(1):以tag为student为标志建立NodeList,其长度为2,这个是符合逻辑的,但是下面的children的长度老提示是5,开始时令我很郁闷,后来查书和上网看了一下,才知道原来
<student name="姚明">
<sex>男</sex>他们两个之间是有空格的,他们之间的空格也算一个Node,所以才形成了注释(2)(3)的item标号为1,3。书上说有办法吧他们之间的空格去掉,其给的一个办法是用以下方法:
for(int i=0;i<list.getLength();i++)
{
Node child = list.item(i);
if(child instanceof Element)
{
Element childElement = (Element)child;
System.out.println(childElement.getTextContent());
}
}
但我认为是没必要,因为它实际上是把空格去掉或者再添加到一个NodeList中,我认为完全没有这个必要,还有另一个方法就是再写入的时候注明文档的文档类型,其实我不知道注释(0)的作用,一开始感觉应该跟刚才的空格问题有关,但是后来试了一下发现有没有这行代码都没有什么影响,不知道为什么。如果大家看了还有什么不明白的地方可以共同探讨一下,我也还有很多要学习的地方。
import java.io.Serializable;
public class StudentBean implements Serializable
{
String name;
String sex;
String phone;
public StudentBean(String name, String sex, String phone) {
super();
this.name = name;
this.sex = sex;
this.phone = phone;
}
public StudentBean()
{};
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public String getPhone() {
return phone;
}
public void setPhone(String phone) {
this.phone = phone;
}
}
写操作是如下:
import org.w3c.dom.*;
import javax.xml.parsers.*;
import javax.xml.transform.*;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import java.io.*;
import java.util.Vector;
public class writexml {
private Document document;
private String filename;
public writexml(String name) throws ParserConfigurationException{
filename=name;
DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance();
DocumentBuilder builder=factory.newDocumentBuilder();
document=builder.newDocument();
}
public void toWrite(Vector<StudentBean> stu_vector)
{
Element root = document.createElement("seller_record");
document.appendChild(root);
for(int i = 0;i<stu_vector.size();i++)
{
StudentBean stu = (StudentBean) stu_vector.get(i);
Element student = document.createElement("student");
student.setAttribute("name",stu.name);
root.appendChild(student);
Element sex = document.createElement("sex");
student.appendChild(sex);
Text tsex = document.createTextNode(stu.sex);
sex.appendChild(tsex);
Element phone = document.createElement("phone");
student.appendChild(phone);
Text tphone = document.createTextNode(stu.phone);
phone.appendChild(tphone);
}
}
public void toSave(){
try{
TransformerFactory tf=TransformerFactory.newInstance();
Transformer transformer=tf.newTransformer();
DOMSource source=new DOMSource(document);
transformer.setOutputProperty(OutputKeys.ENCODING,"GB2312");
transformer.setOutputProperty(OutputKeys.INDENT,"yes");
PrintWriter pw=new PrintWriter(new FileOutputStream(filename));
StreamResult result=new StreamResult(pw);
transformer.transform(source,result);
}
catch(TransformerException mye){
mye.printStackTrace();
}
catch(IOException exp){
exp.printStackTrace();
}
}
public static void main(String args[]){
Vector<StudentBean> stu_vector = new Vector<StudentBean>();
StudentBean stu = new StudentBean("姚明","男","123456");
stu_vector.add(stu);
stu = new StudentBean("刘翔","女","0988556");
stu_vector.add(stu);
try{
writexml myxml=new writexml("E:\\软件\\eclipse\\workstation\\IOxml\\src\\seller.xml");
myxml.toWrite(stu_vector);
myxml.toSave();
System.out.print("Your writing is successful.");
}
catch(ParserConfigurationException exp){
exp.printStackTrace();
System.out.print("Your writing is failed.");
}
}
}
下面是读操作:
import java.io.*;
import java.util.Vector;
import javax.xml.parsers.*;
import org.w3c.dom.*;
public class readxml {
static Document document;
private boolean validating;
public readxml() {
}
public Vector<StudentBean> toRead(String filename)
{
Vector<StudentBean> stu_vector=new Vector<StudentBean>();
StudentBean stu = new StudentBean();
try {
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
factory.setIgnoringElementContentWhitespace(true);
factory.setValidating(validating);
DocumentBuilder builder = factory.newDocumentBuilder();
document = builder.parse(new File(filename));
// document.getDocumentElement().normalize();//注释(0)
Element root = document.getDocumentElement();
NamedNodeMap attr;
NodeList children = root.getElementsByTagName("student");//注释(1)
attr = root.getAttributes();
if(attr!=null)
{
for(int i = 0;i<children.getLength();i++)
{
Element element= (Element) children.item(i);
stu.setName(element.getAttribute("name"));
NodeList list = element.getChildNodes();
System.out.println(list.getLength());
Node child = list.item(i);
System.out.println(element.getAttribute("name"));
System.out.println(list.item(1).getTextContent());//注释(2)
System.out.println(list.item(3).getTextContent());//注释(3)
stu.setName(element.getAttribute("name"));
stu.setSex(list.item(1).getTextContent());
stu.setPhone(list.item(3).getTextContent());
stu_vector.add(stu);
}
}
}
catch (Exception exp)
{
exp.printStackTrace();
return null;
}
return stu_vector;
}
public static void main(String[] args) {
Vector<StudentBean> A = null;
readxml my = new readxml();
A = my.toRead("E:\\软件\\eclipse\\workstation\\IOxml\\src\\seller.xml");
System.out.println(A.size());
System.out.println("asd");
}
}
在下面是我读入的XML格式如下:
<seller_record>
−
<student name="姚明">
<sex>男</sex>
<phone>123456</phone>
</student>
−
<student name="刘翔">
<sex>女</sex>
<phone>0988556</phone>
</student>
</seller_record>
我写入的XML文档根有两个孩子,两个孩子又有3个node;
下面简要谈一下我对读操作的理解(主要是我标的注释的地方):
注释(1):以tag为student为标志建立NodeList,其长度为2,这个是符合逻辑的,但是下面的children的长度老提示是5,开始时令我很郁闷,后来查书和上网看了一下,才知道原来
<student name="姚明">
<sex>男</sex>他们两个之间是有空格的,他们之间的空格也算一个Node,所以才形成了注释(2)(3)的item标号为1,3。书上说有办法吧他们之间的空格去掉,其给的一个办法是用以下方法:
for(int i=0;i<list.getLength();i++)
{
Node child = list.item(i);
if(child instanceof Element)
{
Element childElement = (Element)child;
System.out.println(childElement.getTextContent());
}
}
但我认为是没必要,因为它实际上是把空格去掉或者再添加到一个NodeList中,我认为完全没有这个必要,还有另一个方法就是再写入的时候注明文档的文档类型,其实我不知道注释(0)的作用,一开始感觉应该跟刚才的空格问题有关,但是后来试了一下发现有没有这行代码都没有什么影响,不知道为什么。如果大家看了还有什么不明白的地方可以共同探讨一下,我也还有很多要学习的地方。
发表评论
-
android 横屏重启的解决方案
2011-09-19 15:45 1612Android每次屏幕的横竖切换Activity会重新OnCr ... -
java 类的序列化
2011-08-30 11:57 840序列化: 可以将一个对象保存到一个文件,所以可以通过流的方式 ... -
android全屏显示的方法
2011-08-15 11:16 1475我们在开发程序是经常会需要软件全屏显示、自定义标题(使用按钮等 ... -
模仿AJAX上传文件
2011-07-27 11:08 0首先要说的就是 ajax 是无法实现上传文件的,可以想一下aj ... -
模仿AJAX上传文件
2011-07-27 11:08 666首先要说的就是 ajax 是无法实现上传文件的,可以想一下aj ... -
模仿AJAX上传文件
2011-07-27 11:07 709首先要说的就是 ajax 是无法实现上传文件的,可以想一下aj ... -
模仿AJAX上传文件
2011-07-27 11:07 904首先要说的就是 ajax 是无法实现上传文件的,可以想一下aj ... -
java链接数据库乱码解决方案
2011-05-20 17:56 1278Java乱码问题解决方 ... -
java 连接数据库实例
2011-03-16 11:43 1031package com.dao;import java.sql ... -
java html标签过滤类
2011-02-12 00:24 1224import java.util.regex.Matcher; ... -
java 批量下载图片,批量打包文件并下载
2011-02-11 14:15 17391、批量下载网页上,动态生成的图片到服务器上指定的目录中 2、 ... -
myeclipse 注册的方法
2011-02-11 00:42 700import java.io.BufferedReader;i ... -
利用java.net包访问网络,连接网页并返回html页面代码
2011-02-11 00:28 1456package org.kevin;import java.n ... -
Java清除HTML标签
2011-02-11 00:14 1581使用正则表达式删除HTML标签。 import ja ... -
j2me 环境搭建
2011-01-17 09:17 860用Eclipse和WTK搭建J2ME开发环境 关键字: j2 ... -
jdbc 连接sql2008的问题解决
2010-12-31 16:24 1578首先下JDBC4,然后解压在C ... -
Struts 开发帮助文件
2010-12-25 23:58 606一、 概述struts是基于当前的一些相关标准的开发技术 ... -
java给图片加图片水印
2010-12-08 21:00 802package com.test;import java.aw ... -
java连接数据库大全
2010-11-06 10:30 787JAVA连接数据库大全 关键字: 数据库连接大全 J ... -
两个数组求并集
2010-10-26 22:59 1894对两个数组求并集,由于对数组的操作不是很熟悉,所以将数组中的数 ...
相关推荐
"Find my iPhone"是苹果设备(包括iPhone、iPad和iPod touch)内置的一项重要功能,旨在帮助用户在设备丢失或被盗时追踪并保护其设备。它提供了多种实用工具,以确保用户的数据安全并尽可能找回丢失的设备。以下是该...
Find My iPhone
iPhone4各版本shsh
《iPhone 4 完整电路图PCB详解》 iPhone 4是苹果公司在2010年推出的一款标志性智能手机,其设计与技术在当时堪称业界领先。本篇将深入解析iPhone 4的完整电路图PCB(Printed Circuit Board),帮助读者理解这款设备...
《苹果iPhone 4维修手册与电路图解析》 在电子消费产品领域,苹果公司的iPhone系列一直备受关注。作为第四代产品的iPhone 4,其凭借独特的设计、强大的性能以及优秀的用户体验,成为了当时的标志性设备。本篇将围绕...
iOS 11.4(15F79) (15F5037c)真机包,不需要在更新xcode,直接下载后在访达前往 /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/DeviceSupport 然后载入就行。
这篇文档将深入探讨iPhone 4设备的SHSH备份及其重要性。 首先,理解SHSH的含义至关重要。SHSH代表了设备当前系统状态的哈希值,由Apple的服务器计算得出。当用户尝试恢复或更新iOS设备时,Apple的验证服务器会检查...
### 苹果iPhone4详细评测知识点 #### 一、引言 - **产品背景**:苹果iPhone4被视为“改变一切”的产品,这是苹果公司在2010年推出的第四代iPhone,由苹果公司创始人之一史蒂夫·乔布斯在WWDC(Worldwide Developers...
https://github.com/kamyarelyasi/Libarclite-Files中的libarclite_iphoneos.a
标题中的“iphone4手机shsh”以及描述中的相同内容,主要指的是iPhone 4设备的SHSH备份。在iOS固件更新和降级过程中,SHSH(Secure Hash Storage Signature)扮演了重要角色。SHSH是Apple为每台iOS设备生成的一组...
标题中的“iphone4 -3,1-6.1.2.shsh”暗示了这是一个与苹果公司的iPhone 4设备相关的文件,特别与iOS固件备份有关。SHSH(System Version String Hash Signature)是Apple用于验证iOS设备升级或降级到特定固件时的...
1. **关闭Find My iPhone**:在设置> iCloud> Find My iPhone中关闭该功能,因为越狱过程中可能需要重新激活设备。 2. **运行越狱工具**:选择合适的越狱工具,如红雪(Redsn0w)、绿毒(GreenPois0n)或其他当时...
iphone4越狱软件iphone4越狱软件iphone4越狱软件iphone4越狱软件iphone4越狱软件iphone4越狱软件
在IT行业中,解锁iPhone设备是常见的操作,尤其是对于老款如iPhone 4这样的设备。本文将详细介绍如何解锁iPhone 4,以及在这个过程中可能遇到的问题和解决方案。 首先,我们需要明确解锁的概念。在苹果的世界里,...
标题中的“iphone4 ios6.1.3shsh”指的是苹果公司的iPhone 4智能手机与iOS 6.1.3操作系统的SHSH(System Hash Storage)备份。SHSH是Apple用于验证设备固件更新的一种安全机制,它包含了设备的唯一标识符和对应固件...
【标题】"iPhone4原装部分铃声"指的是那些在苹果公司推出的iPhone 4手机中预装的默认铃声。这些铃声是苹果为了提供给用户个性化手机体验的一部分,它们通常具有高品质的音质和独特的旋律,使得iPhone 4用户在接收到...
iPhone4 english introduction iPhone4 english introduction
标题中的“iPhone4&4S_iPhone4_4S_Ios5_6_主题一键安装包.zip”表明这是一个专为苹果公司的iPhone 4和4S设备设计的主题安装压缩包,适用于运行iOS 5到6系统的设备。这个安装包提供了一个简单的方式,让用户能够快速...
标题中的“iphone4 5.1.1的shsh”指的是iPhone 4设备在iOS 5.1.1版本的SHSH(System Hash Storage Blob)文件。这些文件在苹果的设备更新系统中扮演着关键角色,尤其是对于越狱和降级操作。 SHSH是Apple设备的数字...
标题中的“iphone底座第2级”意味着这是一个关于制作iPhone底座的项目,可能是进阶版或升级版,相比初级版本增加了新的功能或改进了设计。这个DIY项目旨在帮助用户自行动手创建一个适合自己iPhone的底座,既实用又...