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,872 Responses

  1. 헬로밤表示:

    I blog quite often and I truly thank you for your information. This great article has really peaked my interest. I will bookmark your blog and keep checking for new details about once a week. I subscribed to your Feed too.

  2. В магазине сейфов предлагают сейф москва купить сейф москва

  3. Frankevild表示:

    https://ozempic.art/# buy ozempic pills online

  4. В магазине сейфов предлагают сейфы купить в москве где купить сейф

  5. RamonRek表示:

    buy semaglutide pills: rybelsus cost – semaglutide cost

  6. BarryDof表示:

    https://ozempic.art/# buy ozempic

  7. Frankevild表示:

    https://rybelsus.shop/# buy semaglutide online

  8. Jeremypag表示:

    buy ozempic ozempic generic ozempic

  9. LeroyAcuff表示:

    Профессиональный сервисный центр починить телефон ремонт сотовых телефонов

  10. В магазине сейфов предлагают модели сейфов сейф в наличии

  11. BarryDof表示:

    http://rybelsus.shop/# rybelsus price

  12. RamonRek表示:

    buy cheap ozempic: ozempic cost – ozempic cost

  13. Blogging Towards The Bank As Well As More.0 – Who Is It Good To Suit?
    대출 갈아타기

  14. I’m impressed, I have to admit. Seldom do I come across a blog that’s both educative and entertaining, and let me tell you, you’ve hit the nail on the head. The problem is something that not enough people are speaking intelligently about. Now i’m very happy that I stumbled across this in my hunt for something concerning this.

  15. Профессиональный сервисный центр по ремонту сетевых хранилищ в Москве.
    Мы предлагаем: ремонт сетевых хранилищ на дому
    Наши мастера оперативно устранят неисправности вашего устройства в сервисе или с выездом на дом!

  16. Frankevild表示:

    https://rybelsus.shop/# semaglutide online

  17. Профессиональный сервисный центр по ремонту автомагнитол в Москве.
    Мы предлагаем: сервисные центры по ремонт автомагнитол
    Наши мастера оперативно устранят неисправности вашего устройства в сервисе или с выездом на дом!

  18. Jeremypag表示:

    ozempic buy cheap ozempic ozempic cost

  19. Сервисный центр предлагает стоимость ремонта гироскутера supra починка гироскутеров supra

  20. Hi there! I could have sworn I’ve visited this website before but after browsing through some of the articles I realized it’s new to me. Anyways, I’m definitely happy I came across it and I’ll be book-marking it and checking back often!

  21. Jeremypag表示:

    Ozempic without insurance ozempic generic ozempic online

  22. BarryDof表示:

    https://ozempic.art/# Ozempic without insurance

  23. Frankevild表示:

    http://rybelsus.shop/# buy semaglutide pills

  24. RamonRek表示:

    semaglutide online: buy rybelsus online – buy semaglutide online

  25. BarryDof表示:

    https://rybelsus.shop/# rybelsus pill

  26. Профессиональный сервисный центр по ремонту автомагнитол в Москве.
    Мы предлагаем: починить магнитолу
    Наши мастера оперативно устранят неисправности вашего устройства в сервисе или с выездом на дом!

  27. Jeremypag表示:

    ozempic online ozempic coupon buy ozempic

  28. Jeremypag表示:

    ozempic generic ozempic coupon buy ozempic

  29. RamonRek表示:

    Ozempic without insurance: ozempic online – buy ozempic pills online

發佈留言

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