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

14,935 Responses

  1. Albertbiave表示:

    https://usacanadapharm.shop/# usa canada pharm

  2. StephenCer表示:

    global pharmacy canada: canada ed drugs – USACanadaPharm

  3. Albertbiave表示:

    http://usacanadapharm.com/# USACanadaPharm

  4. Dwightkak表示:

    USACanadaPharm: is canadian pharmacy legit – buy prescription drugs from canada cheap

  5. Dwightkak表示:

    usa canada pharm: USACanadaPharm – usa canada pharm

  6. StephenCer表示:

    usa canada pharm: canadian pharmacy in canada – canadapharmacyonline

  7. Albertbiave表示:

    https://usacanadapharm.shop/# best rated canadian pharmacy

  8. TimothyDok表示:

    canada pharmacy online USACanadaPharm usa canada pharm

  9. StephenCer表示:

    USACanadaPharm: USACanadaPharm – northwest pharmacy canada

  10. Albertbiave表示:

    http://usacanadapharm.com/# usa canada pharm

  11. Game_1win_ru表示:

    Официальный TG канал проекта – 1win casinо, теперь в вашем Telegram! Подробнее тут
    https://t.me/Game_1win_ru/832

  12. Dwightkak表示:

    USACanadaPharm: canadian pharmacy checker – USACanadaPharm

  13. Albertbiave表示:

    http://usacanadapharm.com/# reddit canadian pharmacy

  14. StephenCer表示:

    usa canada pharm: USACanadaPharm – pharmacy canadian

  15. Albertbiave表示:

    https://usacanadapharm.com/# legit canadian pharmacy online

  16. Dwightkak表示:

    USACanadaPharm: canadian pharmacy near me – canadian drugs pharmacy

  17. EverettTuh表示:

    buy canadian drugs https://usacanadapharm.shop/# usa canada pharm
    canadian pharmacy victoza

  18. TimothyDok表示:

    usa canada pharm my canadian pharmacy review canadian pharmacy 24

  19. Dwightkak表示:

    USACanadaPharm: USACanadaPharm – online canadian drugstore

  20. JamesBlate表示:

    Официальный TG канал проекта – 7k casinо, теперь в вашем Telegram! Актуальное зеркало, ссылки на вход, промокоды на фриспины, регистрация. слоты, играй на реальные деньги с нами! Сайт 7к казинo
    https://vk.com/slot7kofficial

  21. EverettTuh表示:

    canadian online pharmacy https://usacanadapharm.shop/# USACanadaPharm
    canadian pharmacy antibiotics

  22. Albertbiave表示:

    https://usacanadapharm.shop/# cheapest pharmacy canada

  23. StephenCer表示:

    usa canada pharm: canadian online drugs – USACanadaPharm

  24. Albertbiave表示:

    https://usacanadapharm.shop/# pharmacy canadian

  25. Dwightkak表示:

    legit canadian pharmacy: USACanadaPharm – canadian pharmacy prices

  26. CurtisRix表示:

    Текст

    Bubble Gum является популярным гибридным сортом марихуаны с преобладанием индики. Данный стрейн вызывает оцепенение, которое стирает боль и несколько стимулирует ваш ум. Растаманы часто говорят, что он помогает им оставаться бдительными и творческими, в то время как другие сообщают о том, что у них появляется вдохновение.

    All products are made from 100% organically grown cannabis. Creating the most customized cannabis taste means excellence at every step of the process. From growing to refilling cartridges, innovative technology is present everywhere. Thus, we offer our consumers high-quality, tasty and pure products.
    On this page, we will take a detailed look at the process of ordering a THC vape. Select a device with cannabis liquid, then fill in the necessary information (receipt address, delivery service) and pay for the order. After successful payment, you will be able to receive the parcel without any problems.
    https://secretvape.shop/

  27. Dwightkak表示:

    canada rx pharmacy world: legal canadian pharmacy online – canada drugstore pharmacy rx

  28. xxxxvideos.cc表示:

    Yoour style iss verdy uniquje inn comparisoon to other fllks I
    have rerad stuff from. Thank you forr osting whnen you
    hav the opportunity, Guess I’ll jujst bookmark this
    page.

  29. Albertbiave表示:

    http://usacanadapharm.com/# canadian pharmacies that deliver to the us

發佈回覆給「Dwightkak」的留言 取消回覆

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