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...

9,255 Responses

  1. Jaimevoink表示:

    cipro buy ciprofloxacin over the counter cipro pharmacy

  2. Jaimevoink表示:

    cytotec online buy cytotec in usa order cytotec online

  3. RobertUnmab表示:

    Abortion pills online: buy cytotec online – cytotec online

  4. JimmieTup表示:

    https://azithromycinus.com/# where to get zithromax

  5. Introducing to you the most prestigious online entertainment address today. Visit now to experience now!

  6. Если срочно нужны деньги, воспользуйтесь нашим сервисом. Более 55 МФО готовы предложить вам займы онлайн на карту без отказа срочно . Лояльные условия, моментальная проверка и перевод средств делают нас лучшим выбором для тех, кто не хочет ждать. Получите деньги уже сегодня, без лишних отказов!

  7. ArmandoDat表示:

    clomid tablet: cost of clomid pill – where to get generic clomid pill

  8. RobertUnmab表示:

    how can i get clomid without insurance: can i buy cheap clomid – buy generic clomid

  9. Jaimevoink表示:

    zithromax antibiotic without prescription zithromax price south africa generic zithromax india

  10. Jaimevoink表示:

    buy lisinopril online no prescription india п»їbuy lisinopril 10 mg uk buy lisinopril online india

  11. GeorgeSleld表示:

    Discover Ethena: The Future of DeFi Innovation
    In the rapidly growing world of decentralized finance (DeFi), Ethena is emerging as a leading platform. It offers a secure, decentralized environment where users can access financial products like staking, lending, and yield farming—all powered by blockchain technology.
    ethena
    Why Ethena is Important for DeFi
    Ethena represents the next evolution of DeFi. Unlike traditional finance, where banks and institutions control the flow of capital, Ethena allows individuals to retain full ownership of their assets. This decentralized approach eliminates intermediaries, reduces costs, and creates a more inclusive financial system.

    How Does Ethena Work?
    The Ethena ecosystem provides a suite of decentralized financial products that cater to both investors and developers. Users can stake their crypto assets to earn rewards, participate in governance decisions through the Ethena Fi token, and engage in liquidity pools to maximize their returns.

    Key Benefits of Ethena:
    Control: Users have total control over their digital assets and financial decisions, thanks to Ethena’s decentralized nature.
    Security: Ethena utilizes blockchain security to protect users from hacks and fraud.
    Optimized Returns: Yield farming on Ethena is designed to maximize earnings, helping users get the most out of their investments.
    For anyone looking to invest in DeFi, Ethena offers an easy-to-use, secure, and innovative platform that is reshaping how we think about financial transactions in the digital age.

  12. RobertUnmab表示:

    zestoretic online: lisinopril pill 40 mg – lisinopril 7.5 mg

  13. ArmandoDat表示:

    clomid: can i buy generic clomid – where to get cheap clomid for sale

  14. Предлагаем услуги профессиональных инженеров офицальной мастерской.
    Еслли вы искали ремонт телевизоров samsung сервис, можете посмотреть на сайте: ремонт телевизоров samsung сервис
    Наши мастера оперативно устранят неисправности вашего устройства в сервисе или с выездом на дом!

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

  16. Jaimevoink表示:

    can i get cheap clomid without insurance where can i buy clomid prices can i get clomid pills

  17. RobertUnmab表示:

    how to buy generic clomid: where to get cheap clomid prices – clomid tablets

  18. Jaimevoink表示:

    lisinopril 40 mg cost lisinopril 40 mg coupon lisinopril pill 20mg

  19. Jaimevoink表示:

    buy cipro cheap buy cipro cheap ciprofloxacin

  20. Saniflo WCs表示:

    I came across your own weblog internet site on the internet and appearance a couple of of your earlier posts. Still keep in the really very good operate. I just additional up your Feed to my MSN Information Reader. Seeking toward reading through much more of your stuff afterwards!?–

  21. Introducing to you the most prestigious online entertainment address today. Visit now to experience now!

  22. Jaimevoink表示:

    can i get generic clomid pills how to get cheap clomid for sale where to buy cheap clomid tablets

  23. RobertUnmab表示:

    cytotec buy online usa: Misoprostol 200 mg buy online – Misoprostol 200 mg buy online

  24. ArmandoDat表示:

    order lisinopril online from canada: buy lisinopril – lisinopril 20 mg india

  25. ArmandoDat表示:

    zithromax over the counter canada: zithromax 250 mg tablet price – zithromax 500mg over the counter

  26. Introducing to you the most prestigious online entertainment address today. Visit now to experience now!

  27. ArmandoDat表示:

    buy cytotec over the counter: buy cytotec pills – cytotec buy online usa

發佈留言

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