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

  1. Looking For Inspiration? Check Out Online Shopping Uk
    Sites Artist Grade Linseed Oil (https://vimeo.com)

  2. Allenacurf表示:

    pharmacie en ligne livraison europe: kamagra gel – Pharmacie sans ordonnance

  3. RobertBlica表示:

    https://kamagraenligne.com/# pharmacie en ligne france pas cher

  4. This Is The Advanced Guide To Charity Shop Online Clothes Uk Boy Fishing Garden Ornament

  5. IgnacioSlima表示:

    Viagra pas cher livraison rapide france: viagra en ligne – Viagra vente libre pays

  6. RobertBlica表示:

    https://viaenligne.shop/# Viagra femme ou trouver

  7. here表示:

    You consistently produce high-quality content that is both informative and enjoyable to read. This post was no exception. Keep it up!pulsepeak

  8. GeorgeDaf表示:

    pharmacie en ligne: kamagra pas cher – vente de mГ©dicament en ligne

  9. Allenacurf表示:

    pharmacie en ligne france fiable: cialis sans ordonnance – pharmacie en ligne fiable

  10. Allenacurf表示:

    pharmacie en ligne avec ordonnance: levitra generique – pharmacie en ligne fiable

  11. GeorgeDaf表示:

    acheter mГ©dicament en ligne sans ordonnance: cialis sans ordonnance – Pharmacie Internationale en ligne

  12. 20 Fun Informational Facts About Online Home Shop Uk
    Discount Code Century Lacrosse Wheel Bearings

  13. IgnacioSlima表示:

    pharmacie en ligne pas cher: pharmacie en ligne sans ordonnance – pharmacie en ligne france pas cher

  14. RobertBlica表示:

    https://cenligne.shop/# pharmacie en ligne france pas cher

  15. Allenacurf表示:

    pharmacie en ligne livraison europe: cialis generique – pharmacie en ligne sans ordonnance

  16. Allenacurf表示:

    pharmacie en ligne: pharmacie en ligne – vente de mГ©dicament en ligne

  17. GeorgeDaf表示:

    pharmacie en ligne france fiable: Levitra pharmacie en ligne – pharmacie en ligne france livraison belgique

  18. IgnacioSlima表示:

    vente de mГ©dicament en ligne: levitra generique – п»їpharmacie en ligne france

  19. Prefer Online Casino Sites – Decline To Pornography 프라그마틱플레이

  20. Allenacurf表示:

    pharmacie en ligne pas cher: Acheter Cialis – pharmacie en ligne france livraison internationale

  21. Allenacurf表示:

    trouver un mГ©dicament en pharmacie: Cialis sans ordonnance 24h – pharmacie en ligne

  22. Allenacurf表示:

    pharmacie en ligne fiable: pharmacie en ligne sans ordonnance – pharmacie en ligne avec ordonnance

  23. FobertWen表示:

    На сегодняшний день, когда диплом является началом удачной карьеры в любой области, многие ищут максимально быстрый путь получения образования. Факт наличия документа об образовании трудно переоценить. Ведь именно диплом открывает дверь перед любым человеком, который собирается вступить в профессиональное сообщество или учиться в ВУЗе.
    Мы предлагаем быстро получить любой необходимый документ. Вы можете заказать диплом нового или старого образца, что является отличным решением для человека, который не смог завершить образование или утратил документ. Все дипломы изготавливаются с особой тщательностью, вниманием ко всем нюансам, чтобы в результате получился полностью оригинальный документ.
    Преимущество такого решения заключается не только в том, что можно оперативно получить свой диплом. Процесс организован комфортно, с нашей поддержкой. Начав от выбора нужного образца диплома до консультаций по заполнению персональной информации и доставки по России — все будет находиться под абсолютным контролем опытных специалистов.
    Всем, кто ищет оперативный способ получения требуемого документа, наша услуга предлагает отличное решение. Заказать диплом – это значит избежать долгого обучения и сразу перейти к своим целям: к поступлению в университет или к началу успешной карьеры.

    http://http://diplomsagroups.com/diplomy-po-specialnosti/diplom-stroitelya.html

  24. EdwardGROOM表示:

    Achat mГ©dicament en ligne fiable: Levitra 20mg prix en pharmacie – pharmacie en ligne pas cher

  25. nexusnook表示:

    Information About Creating A Blog nexusnook

  26. Allenacurf表示:

    Acheter viagra en ligne livraison 24h: Viagra generique en pharmacie – Meilleur Viagra sans ordonnance 24h

  27. Allenacurf表示:

    Viagra pas cher inde: Meilleur Viagra sans ordonnance 24h – Viagra homme sans prescription

  28. EdwardGROOM表示:

    pharmacie en ligne france pas cher: levitra generique prix en pharmacie – pharmacie en ligne avec ordonnance

  29. Allenacurf表示:

    pharmacie en ligne avec ordonnance: pharmacies en ligne certifiГ©es – pharmacie en ligne france pas cher

  30. Allenacurf表示:

    pharmacie en ligne fiable: levitra generique prix en pharmacie – pharmacie en ligne pas cher

發佈留言

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