`

My iPhone 4 is a lemon, oh my! (updated)

阅读更多
我是要把一个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)的作用,一开始感觉应该跟刚才的空格问题有关,但是后来试了一下发现有没有这行代码都没有什么影响,不知道为什么。如果大家看了还有什么不明白的地方可以共同探讨一下,我也还有很多要学习的地方。
分享到:
评论

相关推荐

    Find my iPhone定位的七种功能

    "Find my iPhone"是苹果设备(包括iPhone、iPad和iPod touch)内置的一项重要功能,旨在帮助用户在设备丢失或被盗时追踪并保护其设备。它提供了多种实用工具,以确保用户的数据安全并尽可能找回丢失的设备。以下是该...

    Find My iPhone

    Find My iPhone

    iPhone4各版本shsh

    iPhone4各版本shsh

    iphone4完整电路图PCB

    《iPhone 4 完整电路图PCB详解》 iPhone 4是苹果公司在2010年推出的一款标志性智能手机,其设计与技术在当时堪称业界领先。本篇将深入解析iPhone 4的完整电路图PCB(Printed Circuit Board),帮助读者理解这款设备...

    Iphone 4_iphone4_

    《苹果iPhone 4维修手册与电路图解析》 在电子消费产品领域,苹果公司的iPhone系列一直备受关注。作为第四代产品的iPhone 4,其凭借独特的设计、强大的性能以及优秀的用户体验,成为了当时的标志性设备。本篇将围绕...

    This iPhone (Model A1863, A1905, A1906, A1907) is running iOS 11.4 (15F79)

    iOS 11.4(15F79) (15F5037c)真机包,不需要在更新xcode,直接下载后在访达前往 /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/DeviceSupport 然后载入就行。

    iphone4手机shsh

    标题中的“iphone4手机shsh”以及描述中的相同内容,主要指的是iPhone 4设备的SHSH备份。在iOS固件更新和降级过程中,SHSH(Secure Hash Storage Signature)扮演了重要角色。SHSH是Apple为每台iOS设备生成的一组...

    iphone4 -3,1-6.1.2.shsh

    标题中的“iphone4 -3,1-6.1.2.shsh”暗示了这是一个与苹果公司的iPhone 4设备相关的文件,特别与iOS固件备份有关。SHSH(System Version String Hash Signature)是Apple用于验证iOS设备升级或降级到特定固件时的...

    libarclite-iphoneos.a

    https://github.com/kamyarelyasi/Libarclite-Files中的libarclite_iphoneos.a

    iphone5 越狱教程(十分详细!!)

    1. **关闭Find My iPhone**:在设置&gt; iCloud&gt; Find My iPhone中关闭该功能,因为越狱过程中可能需要重新激活设备。 2. **运行越狱工具**:选择合适的越狱工具,如红雪(Redsn0w)、绿毒(GreenPois0n)或其他当时...

    iphone4越狱软件

    iphone4越狱软件iphone4越狱软件iphone4越狱软件iphone4越狱软件iphone4越狱软件iphone4越狱软件

    iPhone4各种SHSH备份

    这篇文档将深入探讨iPhone 4设备的SHSH备份及其重要性。 首先,理解SHSH的含义至关重要。SHSH代表了设备当前系统状态的哈希值,由Apple的服务器计算得出。当用户尝试恢复或更新iOS设备时,Apple的验证服务器会检查...

    解锁IPHONE4的方法

    在IT行业中,解锁iPhone设备是常见的操作,尤其是对于老款如iPhone 4这样的设备。本文将详细介绍如何解锁iPhone 4,以及在这个过程中可能遇到的问题和解决方案。 首先,我们需要明确解锁的概念。在苹果的世界里,...

    iphone4原装部分铃声

    【标题】"iPhone4原装部分铃声"指的是那些在苹果公司推出的iPhone 4手机中预装的默认铃声。这些铃声是苹果为了提供给用户个性化手机体验的一部分,它们通常具有高品质的音质和独特的旋律,使得iPhone 4用户在接收到...

    iPhone4 english introduction

    iPhone4 english introduction iPhone4 english introduction

    哆啦A梦QQ皮肤iphone4越狱版

    《哆啦A梦QQ皮肤iPhone4越狱版》是一款专为使用iOS系统并已越狱的iPhone4用户设计的QQ应用程序个性化皮肤。这款皮肤将经典动漫角色哆啦A梦融入了QQ界面,为用户带来全新的视觉体验,使聊天过程更加生动有趣。 在iOS...

    iphone4 5.1.1的shsh

    标题中的“iphone4 5.1.1的shsh”指的是iPhone 4设备在iOS 5.1.1版本的SHSH(System Hash Storage Blob)文件。这些文件在苹果的设备更新系统中扮演着关键角色,尤其是对于越狱和降级操作。 SHSH是Apple设备的数字...

    iphone底座第2级!!!

    标题中的“iphone底座第2级”意味着这是一个关于制作iPhone底座的项目,可能是进阶版或升级版,相比初级版本增加了新的功能或改进了设计。这个DIY项目旨在帮助用户自行动手创建一个适合自己iPhone的底座,既实用又...

    iPhone4_官方原理图

    《iPhone4官方原理图详解》 在电子技术领域,了解一款设备的官方原理图是深入研究其设计思想、工作原理及故障排查的关键。本篇将针对iPhone4的官方原理图进行详细解读,帮助读者理解这款经典手机的硬件构造与电路...

Global site tag (gtag.js) - Google Analytics