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

14,667 Responses

  1. Seu cassino online favorito Blaze

  2. Sua sorte esta no cassino confiavel Blaze

  3. Tqwnie表示:

    order vasotec 10mg – buy xalatan eye drops buy xalatan paypal

  4. Lhaneevige表示:

    It’s amazing for me to have a web site, which is useful in support of my know-how. thanks admin
    arusak-attestats24

    This is very fascinating, You’re a very professional blogger. I have joined your feed and stay up for seeking more of your excellent post. Also, I have shared your website in my social networks

  5. ThomasVew表示:

    https://ataka-titanov-anime.ru/ – эпический аниме-сериал, где человечество борется за выживание в мире, наполненном гигантскими титанами. Динамичные бои, захватывающий сюжет и глубокие персонажи делают этот сериал обязательным к просмотру. Присоединяйтесь к битве!

  6. DwightUnugh表示:

    голяк куб в кубе смотреть онлайн https://golyak-serial-online.ru

  7. DwightUnugh表示:

    голяк смотреть кубик голяк смотреть

  8. CharlesAmoky表示:

    голяк кубик в кубе бесплатно https://golyak-serial-online.ru

  9. O cassino mais popular Blaze

  10. CharlesAmoky表示:

    голяк смотреть онлайн качестве https://golyak-serial-online.ru

  11. kolyaska_aapi表示:

    Самые популярные коляски Tutis, Преимущества колясок Tutis для вашего ребенка, Какой цвет коляски Tutis выбрать?, Секреты долговечности и надежности коляски Tutis, Какие аксессуары выбрать для коляски Tutis?, Tutis: идеальный выбор для активных семей, Почему Tutis лучше конкурентов?, Инструкция по уходу за коляской Tutis, чтобы сохранить отличное состояние, секреты защиты малыша, полезные советы для удобства, подготовка к разным временам года, Какие новшества представляет Tutis?, Как выбрать коляску Tutis с максимальным комфортом для ребенка?, Tutis: элегантность и стиль, Как Tutis помогает справиться с повседневными задачами родителей?, надежность и комфорт в каждом шаге
    коляска tutis коляска tutis .

  12. O melhor cassino para grandes vitorias Blaze

  13. RicardoApore表示:

    what is an online casino bonus gaming bets

  14. I?m not sure where you are getting your info, but good topic. I needs to spend some time learning much more or understanding more. Thanks for great info I was looking for this information for my mission.

  15. RicardoApore表示:

    how to play casino games online for real money online casino

  16. Your blog post resonated with me on so many levels. It’s comforting to know that others share my perspective on this topic.

  17. Desfrute da emocao no melhor cassino Blaze

  18. GeorgeTaw表示:

    мебель купить интернет магазин
    https://formomebel.ru/stoliki/na-osnovanii-iz-metalla

  19. Georgedealp表示:

    смотреть атака титанов https://ataka-titanov-anime.ru

  20. Georgedealp表示:

    смотреть атака титанов в хорошем качестве https://ataka-titanov-anime.ru

  21. Jogue em um cassino confiavel Blaze

  22. GeorgeTaw表示:

    где можно купить мебель
    https://formomebel.ru/stoliki/kruglye

  23. Melhores jogos neste cassino Blaze

  24. Georgedealp表示:

    аниме атака титанов https://ataka-titanov-anime.ru

  25. Lakidjet_ysoi表示:

    лаки джет на деньги лаки джет на деньги .

發佈留言

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