透過Java解析Excel檔案
也是一個工作中遇到的情境,很多單位想讓內部人員利用Excel維護資料(因為維護上比較簡單方便),且想讓這份資料透過網頁呈現給一般網友閱讀,所以整體後端的流程應該是:
- 將維護的Excel透過網頁介面上傳
- 將上傳的Excel轉換成XML
- 網頁去讀取這份XML來呈現
透過以上的三個步驟,就可以完成客戶想要效果。
本範例展示的是讀取Excel的XLS格式(新版Excel為XLSX格式),並轉換成陣列的方法(寫入XML在前面的範例就有了),我們選用讀取Excel的Library是Apache POI,而檔內已經有以下的資料,其中Total是公式欄位,計算Price x Quantity:
ID | Name | Price | Quantity | Total |
100001 | 產品名稱1 | 10 | 5 | 50 |
100002 | 產品名稱2 | 20 | 10 | 200 |
100003 | 產品名稱3 | 30 | 15 | 450 |
以下是讀取的程式範例:
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, ]
is cialis generic Some studies indicate that tetracyclines inhibit inflammatory cell migration and transformation of lymphocytes
Федеральный закон https://zakonobosago.ru “Об обязательном страховании гражданской ответственности владельцев транспортных средств” (ОСАГО)
Здравствуйте!
Приобрести документ о получении высшего образования можно у нас в столице.
ast-diploms.com/kupit-diplom-krasnodar
Привет!
Как правильно купить диплом колледжа и пту в России, подводные камни
mans-diplom.ru
Привет, друзья!
Покупка диплома о среднем полном образовании: как избежать мошенничества?
yacina.net/купить-диплом-о-высшем-образовании-ре
Будем рады вам помочь!.
car shipping companies cross country car shipping companies cross country .
Howdy! I simply wish to give a huge thumbs up for the nice info you might have here on this post. I might be coming again to your weblog for extra soon.
This website online is known as a stroll-by for all the info you wanted about this and didn?t know who to ask. Glimpse right here, and you?ll positively uncover it.
cross country auto shipping cross country auto shipping .
how to transport car across country how to transport car across country .
shipping car accross country http://Car-shipping24.com/ .
cross country car transport cross country car transport .
shipping car cross country shipping car cross country .
car transport country http://www.Car-shipping24.com .
enclosed auto transport services enclosed auto transport services .
auto transport enclosed hauler Autoshipping24.com .
shipping car enclosed http://www.Autoshipping24.com/ .
enclosed car transport service enclosed car transport service .
enclosed carrier car shipping enclosed carrier car shipping .
enclosed car shipping carriers enclosed car shipping carriers .
enclosed car transport enclosed car transport .
Добрый день!
Купить диплом ВУЗа.
site2.liodiz.ru/2024/07/04/shirokiy-vybor-dokumentov-v-znamenitom-onlayn-magazine
Simply desire to say your article is as surprising. The clarity to your put up is just excellent and i could suppose you are a professional on this subject. Fine together with your permission allow me to grab your RSS feed to stay up to date with imminent post. Thanks one million and please carry on the rewarding work.
hytrin order – order hytrin 5mg generic generic priligy 30mg
Another thing I’ve really noticed is the fact that for many people, poor credit is the result of circumstances outside of their control. By way of example they may have already been saddled by having an illness and as a consequence they have more bills going to collections. It could be due to a occupation loss or even the inability to work. Sometimes divorce can send the funds in a downward direction. Thanks for sharing your thinking on this blog.
kliknД›te nynГ
order balloon compositions https://buy-balloons-dubai.com
order balloons for a holiday balloon for children
Специальные промокоды для вас. https://free-promocode.ru .
Здравствуйте!
Заказать документ о получении высшего образования вы сможете в нашей компании в Москве.
diplomasx.com/kupit-diplom-specialista