Java針對XML檔案的操作大集合

XML是工作上常用到的資料交換格式,會需要利用JAVA進行XML資料的新增、修改或刪除,這裡把相關的方法記錄下來。

下述範例會存取在C:\Projects\Javas\中的sample.xml檔,而檔案中已經有以下的內容:

<?xml version="1.0" encoding="utf-8"?>

<root> 
  <item> 
    <productID>10001</productID>  
    <productName>產品名稱1</productName>  
    <productPrice>10</productPrice> 
  </item>
  <item> 
    <productID>10002</productID>  
    <productName>產品名稱2</productName>  
    <productPrice>20</productPrice> 
  </item>  
  <item> 
    <productID>10003</productID>  
    <productName>產品名稱3</productName>  
    <productPrice>30</productPrice> 
  </item>
</root>

利用Java存取XML我選用的Library是dom4j,可參考官網的介紹,以下是JAVA存取的程式範例:

package CDIT.stanley;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.util.Iterator;

import org.dom4j.io.OutputFormat;
import org.dom4j.io.XMLWriter;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;


public class dom4jXMLFullSample {
	
	//新增XML Node內容
	public static String XMLAppendNode(String xmlFilePath, String productID, String productName, String productPrice){
		
		String appendStatus = "0";
		
		try {
			
			SAXReader reader = new SAXReader();
			Document document = reader.read(xmlFilePath);
			Element root = document.getRootElement();
			Element item = root.addElement("item");
			
			item.addElement("productID").setText(productID);
			item.addElement("productName").setText(productName);
			item.addElement("productPrice").setText(productPrice);
			
			OutputFormat format = OutputFormat.createPrettyPrint();
		    format.setEncoding("utf-8");
		    XMLWriter writer = new XMLWriter(new FileOutputStream(xmlFilePath),format);
		    writer.write(document);
		    writer.close();
		    appendStatus = "1";
			
		} catch (DocumentException e) {
			return appendStatus;
		} catch (UnsupportedEncodingException e) {
			return appendStatus;
		} catch (FileNotFoundException e) {
			return appendStatus;
		} catch (IOException e) {
			return appendStatus;
		}
		return appendStatus;
			
	}
	
	//修改XML Node內容
	public static String XMLChangeNodeValue(String xmlFilePath, String productID, String productName, String productPrice){
		
		String updateStatus = "0";
		
		try {
			SAXReader reader = new SAXReader();
			Document document = reader.read(xmlFilePath);
			Element root = document.getRootElement();
			@SuppressWarnings("rawtypes")
			Iterator it = root.elementIterator();
	        
			while (it.hasNext()) {
	            Element element = (Element) it.next();	            
	            if(productID.equals(element.elementText("productID"))){	            	
	    		    try {
	    		    	
		            	element.element("productName").setText(productName);
		            	element.element("productPrice").setText(productPrice);
		            	
		            	OutputFormat format = OutputFormat.createPrettyPrint();
		    		    format.setEncoding("utf-8");
		    		    XMLWriter writer = new XMLWriter(new FileOutputStream(xmlFilePath),format);
						writer.write(document);
						writer.close();
						updateStatus = "1";
					} catch (IOException e) {
						return updateStatus;
					}	    		   
				}
	        }
			return updateStatus;
		} catch (DocumentException e) {
			return updateStatus;
		}

	}
	
	//刪除XML Node
	public static String XMLRemoveNode(String xmlFilePath , String productID){
		String removeStatus = "0";
		
		try {
			SAXReader reader = new SAXReader();
			Document document = reader.read(xmlFilePath);
			Element root = document.getRootElement();
			@SuppressWarnings("rawtypes")
			Iterator it = root.elementIterator();
	        
			while (it.hasNext()) {
	            Element element = (Element) it.next();
	            if(productID.equals(element.elementText("productID"))){  	
	    		    try {
		            	element.element("item");
		            	element.detach();
		            	
		            	OutputFormat format = OutputFormat.createPrettyPrint();
		    		    format.setEncoding("utf-8");
		    		    XMLWriter writer = new XMLWriter(new FileOutputStream(xmlFilePath),format);
						writer.write(document);
						writer.close();
						removeStatus = "1";
					} catch (IOException e) {
						return removeStatus;
					}
				}	            
	        }
			return removeStatus;
		} catch (DocumentException e) {
			return removeStatus;
		}

	}
	
	public static void main (String[] args){
		String xmlFilePath = "C:\\Projects\\Javas\\sample.xml";
		//新增
		XMLAppendNode(xmlFilePath , "10004", "產品名稱4", "40");
		//修改
		XMLChangeNodeValue (xmlFilePath , "10001", "測試修改", "100");
		//刪除
		XMLRemoveNode (xmlFilePath , "10002");
	}
}

上述程式進行完後,會將原本的XML檔變成如下的內容:

<?xml version="1.0" encoding="utf-8"?>

<root> 
  <item> 
    <productID>10001</productID>  
    <productName>測試修改</productName>  
    <productPrice>100</productPrice> 
  </item>  
  <item> 
    <productID>10003</productID>  
    <productName>產品名稱3</productName>  
    <productPrice>30</productPrice> 
  </item>  
  <item> 
    <productID>10004</productID>  
    <productName>產品名稱4</productName>  
    <productPrice>40</productPrice> 
  </item> 
</root>

You may also like...

7,833 Responses

  1. I used to be able to find good advice from your articles.

  2. Timothyzew表示:

    http://avanafil.pro/# farmacie online autorizzate elenco

  3. TomasRop表示:

    Farmacia online piГ№ conveniente: kamagra oral jelly – acquistare farmaci senza ricetta

  4. TomasRop表示:

    п»їFarmacia online migliore: avanafil senza ricetta – farmacia online senza ricetta

  5. Trefxsd表示:

    Привет!
    Всё, что нужно знать о покупке аттестата о среднем образовании
    mandiplomiks.ru/attestat-za-9-klass
    Будем рады вам помочь!.

  6. Wisdom On Double Sided Dildos From An Older Five-Year-Old double Dildo toys

  7. Lazrjuu表示:

    Привет, друзья!
    Мы можем предложить дипломы любой профессии по приятным тарифам.
    rushkas-diplomasxx.ru/kupit-diplom-bukhgaltera

  8. RandyLunda表示:

    acquisto farmaci con ricetta: Avanafil 50 mg – Farmacia online miglior prezzo

  9. I am typically to blogging and i truly appreciate your articles. This content has truly peaks my interest. My goal is to bookmark your website and maintain checking achievable information.

  10. Efren表示:

    Guide To How To Get Diagnosis For ADHD: The Intermediate Guide Towards How
    To Get Diagnosis For ADHD get diagnosis for adhd, Efren,

  11. there are many dating services on the internet and i also join some of them..

  12. TomasRop表示:

    п»їFarmacia online migliore: Farmacie online sicure – farmacie online sicure

  13. TomasRop表示:

    viagra naturale in farmacia senza ricetta: viagra online siti sicuri – viagra 100 mg prezzo in farmacia

  14. Just want to say your article is as amazing. The clarity in your post is just nice and i can assume you’re an expert on this subject. Well with your permission allow me to grab your feed to keep updated with forthcoming post. Thanks a million and please continue the enjoyable work. que es el acne

  15. Mazrtdv表示:

    Привет, друзья!
    Сколько стоит диплом высшего и среднего образования и как его получить?
    rushkadiplomik.ru

  16. Whitescreen58表示:

    Nice post. I learn something new and challenging on websites I stumbleupon everyday. It will always be helpful to read content from other authors and use a little something from other websites.

  17. RandyLunda表示:

    Farmacie online sicure: avanafil in farmacia – Farmacie on line spedizione gratuita

  18. NathanDum表示:

    Link pyramid, tier 1, tier 2, tier 3
    Primary – 500 links with inclusion inside pieces on publishing portals

    Secondary – 3000 link Rerouted references

    Level 3 – 20000 hyperlinks mix, remarks, writings

    Utilizing a link network is helpful for web crawlers.

    Demand:

    One reference to the site.

    Query Terms.

    Accurate when 1 key phrase from the page topic.

    Remark the extra service!

    Essential! Tier 1 hyperlinks do not overlap with Secondary and Tertiary-level connections

    A link pyramid is a tool for increasing the flow and link profile of a online platform or online community

  19. 10 Double Glazed Window Repair Hacks All Experts Recommend window repairs near Me

  20. Diplomi_uqEa表示:

    Привет, друзья!
    Приобрести документ о получении высшего образования можно в нашей компании.
    rushkas-diplom.ru

  21. 15 Amazing Facts About Best 18 Wheeler Accident Attorneys 18 Wheeler Accident Lawsuits

  22. Howdy! I could have sworn I’ve been to this web site before but after going through a few of the articles I realized it’s new to me. Anyhow, I’m definitely pleased I found it and I’ll be bookmarking it and checking back frequently.

  23. Timothyzew表示:

    http://avanafil.pro/# top farmacia online

  24. Timothyzew表示:

    http://avanafil.pro/# farmaci senza ricetta elenco

  25. TomasRop表示:

    farmacie online sicure: Avanafil prezzo – top farmacia online

  26. TomasRop表示:

    viagra pfizer 25mg prezzo: viagra prezzo – viagra naturale

  27. cooking is my passion and a hobby for me, besides, i love to eat lots of foods-

  28. Who Is Responsible For An Glass Repair Milton Keynes Budget?
    12 Best Ways To Spend Your Money emergency locksmith milton keynes

  29. 10 Amazing Graphics About Bunk Bed Double Bottom
    Single Top cheap triple bunk beds

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。