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

25,690 Responses

  1. Josephsip表示:

    alo789: alo 789 – 789alo

  2. BernardFax表示:

    alo789hk: alo789 chinh th?c – alo 789 dang nh?p

  3. There are definitely a whole lot of particulars like that to take into consideration. That is a nice point to deliver up. I provide the ideas above as general inspiration but clearly there are questions like the one you bring up where crucial thing might be working in sincere good faith. I don?t know if finest practices have emerged round issues like that, however I’m positive that your job is clearly recognized as a fair game. Both boys and girls really feel the impression of just a moment’s pleasure, for the rest of their lives.

  4. Curtismence表示:

    https://88betviet.pro/# keo nha cai 88bet

  5. Rubengax表示:

    188bet 88bet 188bet 88bet 88bet

  6. Josephsip表示:

    k8vip: link vao k8 – k8vip

  7. Unquestionably believe that which you said. Your favorite justification seemed to be on the web the simplest thing to be aware of. I say to you, I certainly get irked while people consider worries that they just don’t know about. You managed to hit the nail upon the top and defined out the whole thing without having side-effects , people can take a signal. Will likely be back to get more. Thanks

  8. closings are dead-on and i will forthwith subscribe for your rss nourish to stay as much date with your up approaching postings. Sure! I confess it, your

  9. Stevenkated表示:

    https://88betviet.pro/# 188bet 88bet

  10. BMW_bbmt表示:

    BMW X6: идеально для активной жизни, узнайте.
    Превосходство BMW X6 на дороге, водителей.
    дизайн.
    Стильный и агрессивный BMW X6, высокой техники.
    Как BMW X6 меняет правила игры, настоящего монстра.
    Кроссовер BMW X6, который стоит выбрать, решение.
    Роскошь внутри BMW X6, исключительное качество.
    Ваш надежный спутник – BMW X6, постоянно.
    Узнайте, почему BMW X6 так популярен, в нашем исследовании.
    Мощь и маневренность BMW X6, впечатляют.
    Обеспечьте свою безопасность с BMW X6, в приоритете.
    Почему BMW X6 – это лучшее решение, новые стандарты.
    Инновации в BMW X6, меняют.
    Как будет ощущаться поездка на BMW X6, подробности.
    Что дает вам BMW X6?, в нашем анализе.
    BMW X6: стиль, который невозможно не заметить, выразит вашу индивидуальность.
    Как BMW X6 выглядит на фоне конкурентов, в нашем сравнении.
    Мнения о BMW X6 от реальных пользователей, в нашем разделе.
    Новые технологии безопасности в BMW X6, защитят вас.
    BMW X6: наш окончательный вердикт, предлагаем выводы.
    bmw-x6.biz.ua bmw-x6.biz.ua .

  11. Curtismence表示:

    https://alo789.auction/# alo789 chinh th?c

  12. Stevenkated表示:

    http://alo789.auction/# dang nh?p alo789

  13. EdwardLap表示:

    нажмите, чтобы подробнее
    бизнес по переработке мусора

  14. Rubengax表示:

    link vao k8 nha cai k8 link vao k8

  15. BernardFax表示:

    k8: k8vip – link vao k8

  16. In Singapore, monetary companies are highly regulated by The Monetary Authority of Singapore (MAS), the regulator and supervisor of monetary establishments in Singapore.

  17. EdwardLap表示:

    посмотреть в этом разделе
    оборудование для переработки

  18. BMW_bimt表示:

    Новый BMW X6: стиль и мощь, совершенного кроссовера.
    Комфорт и стиль в BMW X6, вдохновлять.
    Погрузитесь в.
    Уникальный дизайн BMW X6, поклонников.
    BMW X6: мощь на каждый день, узнайте.
    BMW X6: лучшее сочетание цены и качества, решение.
    Потрясающая отделка и материалы в BMW X6, подчеркивают.
    Незаменимый помощник на дороге – BMW X6, предоставляет.
    Причины популярности BMW X6, в нашем обзоре.
    Динамичный BMW X6 – для активной жизни, впечатляют.
    Надежность и безопасность BMW X6, в приоритете.
    Почему BMW X6 – это лучшее решение, новые возможности.
    Технологический прогресс BMW X6, улучшают.
    Как BMW X6 спроектирован для вашего комфорта, функции.
    Что дает вам BMW X6?, в нашем анализе.
    Выразительный дизайн BMW X6, подчеркнет ваш статус.
    BMW X6 против других SUV, в нашем сравнении.
    Мнения о BMW X6 от реальных пользователей, в нашей статье.
    Новые технологии безопасности в BMW X6, гарантируют вашу безопасность.
    Итоги: BMW X6, как лучший выбор, подводим итоги.
    bmw i 4 bmw i 4 .

  19. Davidriday表示:

    balloon игра balloon игра Обнаружьте новые стратегии РЅР° автомате Ballon.

發佈回覆給「heating and cooling companies」的留言 取消回覆

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