透過Java解析Excel檔案

也是一個工作中遇到的情境,很多單位想讓內部人員利用Excel維護資料(因為維護上比較簡單方便),且想讓這份資料透過網頁呈現給一般網友閱讀,所以整體後端的流程應該是:

  1. 將維護的Excel透過網頁介面上傳
  2. 將上傳的Excel轉換成XML
  3. 網頁去讀取這份XML來呈現

透過以上的三個步驟,就可以完成客戶想要效果。

本範例展示的是讀取Excel的XLS格式(新版Excel為XLSX格式),並轉換成陣列的方法(寫入XML在前面的範例就有了),我們選用讀取Excel的Library是Apache POI,而檔內已經有以下的資料,其中Total是公式欄位,計算Price x Quantity:

IDNamePriceQuantityTotal
100001產品名稱110550
100002產品名稱22010200
100003產品名稱33015450

以下是讀取的程式範例:

package CDIT.stanley;

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.Iterator;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;


public class excelToXMLFullSample {
	
	static ArrayList<ArrayList<String>> excelData = new ArrayList<ArrayList<String>>();
	
	public static void main (String[] args) throws FileNotFoundException{
		
		excelData.clear();
	    
	    String xlsPath = "C:\\Projects\\Javas\\sample.xls";
	    InputStream inputStream = null;
	    inputStream = new FileInputStream (xlsPath);
		POIFSFileSystem fileSystem = null;
	    try {
	        fileSystem = new POIFSFileSystem (inputStream);
			@SuppressWarnings("resource")
			HSSFWorkbook workBook = new HSSFWorkbook (fileSystem);
	        HSSFSheet sheet = workBook.getSheetAt (0);
	        Iterator<?> rows = sheet.rowIterator ();
	        
	        while (rows.hasNext ()){
	            HSSFRow row = (HSSFRow) rows.next();
	            Iterator<?> cells = row.cellIterator ();

	            ArrayList<String> rowData = new ArrayList<String>();
	            
	            while (cells.hasNext ()){
	                HSSFCell cell = (HSSFCell) cells.next();
	                
	                switch (cell.getCellTypeEnum()){
		                case STRING :{
		                    rowData.add(cell.getStringCellValue());
		                    break;
		                }
		                case NUMERIC : {
		                    rowData.add((int)cell.getNumericCellValue() + "");
			                break;
		                }
		                case FORMULA :{
		                	switch(cell.getCachedFormulaResultTypeEnum()) {
			                    case STRING:
			                    	rowData.add(cell.getStringCellValue ());
			                        break;
			                    case NUMERIC:
			                    	rowData.add((int)cell.getNumericCellValue() + "");
			                        break;
					default:
						rowData.add("");
						break;
		                	}
		                }		                
			default:
				rowData.add("");
				break;
	                }
	            }
	            excelData.add(rowData);
	        }
	    } catch(IOException e){
	        System.out.println("IOException " + e.getMessage());
	        System.out.println("轉換失敗,請檢查Excel檔案與格式是否正確");
	    }
	    for(int i=0 ; i<excelData.size(); i++){
	    	System.out.println("Excel Row "+ i +" Data : " + excelData.get(i));
	    }
	    
	}
}

程式會把Excel內的資料轉換為ArrayList,輸出內容如下:

Excel Row 0 Data : [Product ID, Product Name, Product Price, Quantity, Total]
Excel Row 1 Data : [100001, 產品名稱1, 10, 5, 50, ]
Excel Row 2 Data : [100002, 產品名稱2, 20, 10, 200, ]
Excel Row 3 Data : [100003, 產品名稱3, 30, 15, 450, ]

You may also like...

27,083 Responses

  1. Perryzoozy表示:

    pharmacie en ligne sans ordonnance Pharmacies en ligne certifiees pharmacie en ligne fiable

  2. Jacobbep表示:

    pharmacie en ligne france livraison internationale https://tadalafilmeilleurprix.com/# Pharmacie Internationale en ligne

  3. Jacobbep表示:

    pharmacies en ligne certifiГ©es https://kamagrameilleurprix.com/# pharmacies en ligne certifiГ©es

  4. Eltonkep表示:

    кракен рабочая ссылка – площадка kraken, kraken ссылка зеркало официальный сайт

  5. NorbertKep表示:

    Acheter viagra en ligne livraison 24h: Viagra sans ordonnance 24h – Viagra pas cher inde

  6. WilsonVah表示:

    Viagra sans ordonnance livraison 48h: acheter du viagra – Viagra Pfizer sans ordonnance

  7. NorbertKep表示:

    pharmacie en ligne france fiable: cialis prix – pharmacie en ligne livraison europe

  8. NorbertKep表示:

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

  9. Richardprurf表示:

    http://viagrameilleurprix.com/# Viagra sans ordonnance pharmacie France
    Achat mГ©dicament en ligne fiable

  10. Perryzoozy表示:

    pharmacie en ligne france livraison belgique kamagra en ligne pharmacie en ligne fiable

  11. Richardprurf表示:

    http://viagrameilleurprix.com/# Viagra pas cher paris
    Pharmacie Internationale en ligne

  12. Eltonkep表示:

    кракен – kraken официальный сайт, кракен москва

  13. Phillipedugs表示:

    Look of the Week: Kendrick Lamar’s Super Bowl pants signal the return of flares
    kraken onion
    This year’s Super Bowl halftime show was hardly a fashion extravaganza, with headliner Kendrick Lamar keeping things simple in a backwards cap and motorbike-style varsity jacket, which he kept on throughout.

    And without the costume-change roulette we’ve come to expect of halftime shows, the internet fixated on one item in particular: his jeans.

    While not quite the bell-bottoms of decades past (the 1970s and the 2000s, specifically), the Compton-born rapper’s washed denim pants flared out at the knee and dragged beneath his heels along the stage at Caesars Superdrome in New Orleans. His silhouette stood in stark contrast to that of record producer Mustard, who made a brief cameo in a pair of outsized jeans straight from the West Coast hip-hop playbook.
    Opinions were, as ever, divided on social media. Some users described Lamar’s flares as “women’s jeans” and “Hannah Montana pants,” earning him comparisons to everyone from Jennifer Aniston to country singer Lainey Wilson. Others joked that their moms were looking for a similar pair or that they nodded to millennials, for whom flares were a teenage staple.

    But those suggesting his style was outdated, or gender-inappropriate, may not have been paying attention to the recent resurgence of flares — in both womenswear and menswear. After all, Lamar’s jeans were designed by one of the most influential figures in modern fashion, Celine’s former creative director Hedi Slimane, before he departed the French label in October.

  14. Jacobbep表示:

    pharmacie en ligne france pas cher http://kamagrameilleurprix.com/# trouver un mГ©dicament en pharmacie

  15. Jacobbep表示:

    pharmacie en ligne france fiable http://viagrameilleurprix.com/# Viagra gГ©nГ©rique pas cher livraison rapide

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

  17. Eltonkep表示:

    kraken магазин – kraken отзывы, kraken зеркала

  18. Perryzoozy表示:

    pharmacie en ligne pas cher pharmacie en ligne france livraison belgique trouver un mГ©dicament en pharmacie

  19. NorbertKep表示:

    pharmacie en ligne france livraison belgique: pharmacie en ligne livraison europe – vente de mГ©dicament en ligne

  20. Goudarzi, Sara. “You Cannot Travel Back in Time, Scientists Say.” LiveScience.

  21. Perryzoozy表示:

    pharmacie en ligne pas cher cialis prix pharmacie en ligne france livraison internationale

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

  23. NorbertKep表示:

    Viagra pas cher livraison rapide france: viagra en ligne – Viagra femme sans ordonnance 24h

  24. Richardprurf表示:

    https://tadalafilmeilleurprix.shop/# vente de mГ©dicament en ligne
    pharmacie en ligne france fiable

  25. Richardprurf表示:

    https://viagrameilleurprix.com/# Meilleur Viagra sans ordonnance 24h
    pharmacies en ligne certifiГ©es

  26. Richardprurf表示:

    https://kamagrameilleurprix.com/# pharmacie en ligne
    pharmacie en ligne france livraison internationale

  27. Jacobbep表示:

    Pharmacie en ligne livraison Europe https://kamagrameilleurprix.shop/# pharmacie en ligne france pas cher

  28. Jacobbep表示:

    pharmacie en ligne france livraison internationale http://tadalafilmeilleurprix.com/# pharmacie en ligne

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

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