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

  1. The 10 Scariest Things About Waitrose Groceries
    Online Shopping Uk Waitrose Groceries Online Shopping Uk (http://9D0Br01Aqnsdfay3C.Kr)

  2. 15 Pinterest Boards That Are The Best Of All Time About Door Fitter Crawley Replacement doors near me

  3. Alfie表示:

    How To Save Money On Demo Hades slot demo hades zeus (Alfie)

  4. Are You In Search Of Inspiration? Check Out Mobility Scooter For Elderly Mobility scooter For seniors

  5. Five Killer Quora Answers To Treadmills Sale UK treadmills sale uk

  6. 15 Best Pinterest Boards To Pin On All Time About Online Shopping Sites Clothes Cheap Bettafix Antifungal Remedy

  7. You’ll Be Unable To Guess Fela Attorneys Near Me’s Secrets fela attorneys Near Me

  8. The Most Worst Nightmare About Workers Compensation Litigation Relived workers’ compensation law firm

  9. How To Outsmart Your Boss With CS GO Cases Opening Hydra Case (http://Www.disonde.Com)

  10. The Leading Reasons Why People Perform Well In The Double Glazing Repairs Leeds Industry Double glazed doors repairs

  11. Callie表示:

    You’ll Never Be Able To Figure Out This Online Shopping Uk Amazon’s Secrets online
    shopping uk amazon [Callie]

  12. What’s The Current Job Market For Online Shopping Uk Groceries Professionals
    Like? online Shopping uk Groceries

  13. 10 Unexpected Online Shopping Sites List For Clothes Tips
    Durable Sun Sail Canopy

  14. Are You Getting The Most Out Of Your Novice Slots?
    exciting slots – https://maps.google.ml

  15. Rocco表示:

    Why The Erb’s Palsy Lawsuit Is Beneficial During COVID-19 erb’s palsy attorneys (Rocco)

  16. See What Window Repair Cambridge Tricks The Celebs Are Making Use Of Window repair cambridge

  17. Jznnpj表示:

    purchase piroxicam generic – piroxicam over the counter cost exelon 6mg

  18. You’ll Be Unable To Guess Double Glazed Units Near Me’s
    Tricks double glazed units Near Me

  19. Vimeo.com表示:

    How To Build A Successful Online Clothes Shopping Websites Uk Even If You’re
    Not Business-Savvy Vimeo.com

  20. A Step-By-Step Guide To Search Engine Optimization Agency Website Optimisation Uk (http://Www.Kdthoist.Com)

  21. Software表示:

    Best Backlinking Software Tips To Relax Your Everyday Lifethe Only Best Backlinking Software
    Trick That Every Person Must Learn Software

  22. What’s The Job Market For Treadmill Near Me Professionals?
    treadmill near Me

  23. Vito表示:

    The 10 Most Scariest Things About Online Shopping Top 7 online shopping
    top 7 (Vito)

  24. 10 Reasons Why People Hate Double Glazed Windows Luton. Double Glazed Windows Luton upvc window doctor near me

  25. Why You Should Be Working On This Online Clothes Shopping Websites Uk capezio jr. tyette uk

  26. 20 Things You Should Be Educated About Slot Promotions play slots – https://www.google.ps,

  27. What’s The Current Job Market For Double Glazing Near Me Professionals Like?
    Double Glazing Near Me

  28. Christel表示:

    The 10 Scariest Things About Treadmill UK treadmill uk (Christel)

發佈留言

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