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

6,224 Responses

  1. This design is wicked! You most certainly know how to keep a reader amused. Between your wit and your videos, I was almost moved to start my own blog (well, almost…HaHa!) Great job. I really loved what you had to say, and more than that, how you presented it. Too cool!

  2. A formidable share, I just given this onto a colleague who was doing a bit of analysis on this. And he the truth is bought me breakfast because I discovered it for him.. smile. So let me reword that: Thnx for the treat! But yeah Thnkx for spending the time to debate this, I feel strongly about it and love reading more on this topic. If doable, as you turn into expertise, would you thoughts updating your weblog with more details? It’s extremely helpful for me. Massive thumb up for this weblog submit!

  3. Если вы искали где отремонтировать сломаную технику, обратите внимание – ремонт техники в краснодаре

  4. Если вы искали где отремонтировать сломаную технику, обратите внимание – сервисный центр в краснодаре

  5. Great website you have here but I was wanting to know if you knew of any community forums that cover the same topics talked about in this article? I’d really like to be a part of community where I can get suggestions from other experienced individuals that share the same interest. If you have any suggestions, please let me know. Appreciate it!

  6. Если вы искали где отремонтировать сломаную технику, обратите внимание – техпрофи

  7. MauriceGueda表示:

    purple pharmacy mexico price list: mexican online pharmacies prescription drugs – п»їbest mexican online pharmacies

  8. Lyn表示:

    The 10 Most Terrifying Things About Situs Toto Login situs toto
    login (Lyn)

  9. MauriceGueda表示:

    what’s the best online pharmacy: ventolin inhouse pharmacy – best online pharmacy klonopin

  10. RobertMef表示:

    Online medicine order: buy medicines online in india – reputable indian online pharmacy

  11. Ezra表示:

    Guide To Electric Foldable Wheelchair: The Intermediate Guide On Electric Foldable Wheelchair electric foldable wheelchair; Ezra,

  12. You’ll Never Be Able To Figure Out This Situstoto
    Slot’s Secrets situstoto Slot

  13. RobertMef表示:

    online pharmacy meloxicam: inhouse pharmacy baclofen – people’s pharmacy lisinopril

  14. 12 Companies Are Leading The Way In Program Car Key how To reprogram car key

  15. ArthurKib表示:

    http://mexicopharmacy.cheap/# п»їbest mexican online pharmacies

  16. 888starzMt表示:

    Актуальные предложения 888Starz доступны уже сегодня, не упустите шанс http://kungur.hldns.ru/forum/profile.php?action=show&member=9929

  17. RobertMef表示:

    purple pharmacy mexico price list: mexican online pharmacies prescription drugs – mexican mail order pharmacies

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

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

  20. RobertMef表示:

    mexican mail order pharmacies: pharmacies in mexico that ship to usa – purple pharmacy mexico price list

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

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

  23. MauriceGueda表示:

    india pharmacy: top 10 pharmacies in india – best india pharmacy

  24. Josephfub表示:

    mexican online pharmacies prescription drugs medicine in mexico pharmacies mexico drug stores pharmacies

  25. The 10 Most Scariest Things About Mitsubishi Delica Key Mitsubishi Delica Key

  26. Bedpage表示:

    You need to take part in a contest for one of the highest quality sites online. I will highly recommend this website!

  27. Lazrwec表示:

    Привет!
    Мы предлагаем дипломы любых профессий по выгодным тарифам.
    passneurosurgery.net/learn/blog/index.php?entryid=446988&nonjscomment=1&comment_itemid=446988&comment_context=228393&comment_component=blog&comment_area=format_blog

  28. The Secret Secrets Of Porsche Key Replacement porsche spare key cost

發佈留言

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