一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

java對XML文件的解析、節(jié)點(diǎn)的增加、刪除操作總結(jié)

1、Java代碼:
主要采用dom來進(jìn)行操作
復(fù)制代碼 代碼如下:
package test;
import Java.io.IOException;
import Javax.xml.parsers.DocumentBuilder;
import Javax.xml.parsers.DocumentBuilderFactory;
import Javax.xml.parsers.ParserConfigurationException;
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.NodeList;
import org.w3c.dom.Text;
import org.xml.sax.SAXException;
public class XmlOprate {
Document doc;
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder;
NodeList imags;
String path;
public NodeList getImags() {
return imags;
}
public void setImags(NodeList imags) {
this.imags = imags;
}
/**
* 構(gòu)造方法
* @param path:xml文件的路徑
* @param nodes:要解析的xml節(jié)點(diǎn)名稱
*/
public XmlOprate(String path) {
super();
this.path = path;
System.out.println(System.getProperty("user.dir"));
}
/**
* 解析XML
* @param path
*/
public void readXml(){
try {
builder = factory.newDocumentBuilder();
Document doc=builder.parse(path);
doc.normalize();
NodeList imags =doc.getElementsByTagName("imags");
this.setImags(imags);
for (int i=0;i<imags.getLength();i++){
Element link=(Element) imags.item(i);
System.out.print("title: ");
System.out.println(link.getElementsByTagName("title").item(0).getFirstChild().getNodeValue());
System.out.print("URL: ");
System.out.println(link.getElementsByTagName("url").item(0).getFirstChild().getNodeValue());
System.out.print("imgsrc: ");
System.out.println(link.getElementsByTagName("imgsrc").item(0).getFirstChild().getNodeValue());
System.out.println();
}
}catch (ParserConfigurationException e) {
e.printStackTrace();
} catch (SAXException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
/**
* addCode
* @param path
*/
public void addXmlCode(String imgsrc,String title,String url){
try {
builder = factory.newDocumentBuilder();
Document doc=builder.parse(path);
doc.normalize();
Text textseg;
Element imag=doc.createElement("imags");
Element linkimgsrc=doc.createElement("imgsrc");
textseg=doc.createTextNode(imgsrc);
linkimgsrc.appendChild(textseg);
imag.appendChild(linkimgsrc);
Element linktitle=doc.createElement("title");
textseg=doc.createTextNode(title);
linktitle.appendChild(textseg);
imag.appendChild(linktitle);
Element linkurl=doc.createElement("url");
textseg=doc.createTextNode(url);
linkurl.appendChild(textseg);
imag.appendChild(linkurl);
doc.getDocumentElement().appendChild(imag);
TransformerFactory tFactory =TransformerFactory.newInstance();
Transformer transformer;
transformer = tFactory.newTransformer();
DOMSource source = new DOMSource(doc);
StreamResult result = new StreamResult(new Java.io.File(path));
transformer.transform(source, result);
}catch(Exception e){
}
}
/**
* delete xml code
* @param path
*/
public void delXmlCode(){
try {
builder = factory.newDocumentBuilder();
doc=builder.parse(path);
doc.normalize();
NodeList imags =doc.getElementsByTagName("imags");
Element elink=(Element) imags.item(0);
elink.removeChild(elink.getElementsByTagName("imgsrc").item(0));
elink.removeChild(elink.getElementsByTagName("title").item(0));
elink.removeChild(elink.getElementsByTagName("url").item(0));
doc.getFirstChild().removeChild(elink);
TransformerFactory tFactory =TransformerFactory.newInstance();
Transformer transformer = tFactory.newTransformer();
DOMSource source = new DOMSource(doc);
StreamResult result = new StreamResult(new Java.io.File(path));
transformer.transform(source, result);
} catch (ParserConfigurationException e) {
e.printStackTrace();
} catch (SAXException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} catch (TransformerConfigurationException e) {
e.printStackTrace();
} catch (TransformerException e) {
e.printStackTrace();
}
}
}

2、xml部分
復(fù)制代碼 代碼如下:
<?xml version="1.0" encoding="UTF-8" ?>
<root>
<imags>
<imgsrc>images/ad-01.jpg</imgsrc>
<title>胡志明市</title>
<url>http://torchrelay.beijing2008.cn/cn/journey/hochiminhcity/</url>
</imags>
<imags>
<imgsrc>images/ad-02.jpg</imgsrc>
<title>香港2</title>
<url>http://torchrelay.beijing2008.cn/cn/journey/hongkong/</url>
</imags>
</root>

3、總結(jié):
看對xml操作的三個方法(讀、寫、刪),他們的初始化語句都相同:
復(fù)制代碼 代碼如下:
builder = factory.newDocumentBuilder();
Document doc=builder.parse(path);
doc.normalize();

開始我打算把這部分相同的部分拿出來寫在構(gòu)造方法中,但是在測試中發(fā)現(xiàn),這樣總是會報(bào)空指針的錯誤(搞了我好久);
而只是把
builder = factory.newDocumentBuilder();
放到builder的初始化語句中的時候,讀沒問題,但是當(dāng)寫或者刪的時候也會報(bào)錯;
所以就寫成現(xiàn)在這樣了,感覺有點(diǎn)亂亂的,但也沒想到什么好的方法,就先貼到這里了,以后可能會用得著

jsp技術(shù)java對XML文件的解析、節(jié)點(diǎn)的增加、刪除操作總結(jié),轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 六月丁香六月婷婷 | a级黄色网址 | 免费黄色视屏 | 亚洲精品小视频 | 一区二区三区四区国产精品 | 国产大片免费观看中文字幕 | 精品国产高清a毛片无毒不卡 | 韩国本免费一级毛片免费 | 伊人久久大香线蕉综合爱婷婷 | 伊人网伊人 | 亚洲精品tv久久久久久久久久 | 影音先锋在线亚洲精品推荐 | 国产精品一区二区久久精品涩爱 | 成人久久伊人精品伊人 | 国产亚洲精品成人a在线 | 亚洲人成绝费网站色ww | 欧美国产综合在线 | 成人免费看www网址入口 | 久久久久亚洲香蕉网 | 四虎影视在线观看永久地址 | 成 人 黄 色 视频免费播放 | 国产精品第 | 精品国产免费观看 | 国产在线精品一区二区三区不卡 | 五月综合激情视频在线观看 | 日本欧美强乱视频在线 | 国产精品嫩草影视在线观看 | 国产精品视频一区二区猎奇 | 精品国产91乱码一区二区三区 | 婷婷激情五月综合 | 久久精品国产99国产精品 | 色美女在线 | 国产免费69成人精品视频 | 色77影院| 国产美女在线精品亚洲二区 | 日本久久伊人 | 自拍偷自拍亚洲精品被多人伦好爽 | 香港三级欧美国产精品 | 久久久久久久久久综合情日本 | 五月天激情婷婷 | 五月综合色啪 |