場(chǎng)景:對(duì)于經(jīng)常需要導(dǎo)入Excel模板或數(shù)據(jù)來(lái)解析后加以應(yīng)用的,使用頻率非常之高,做了一個(gè)比較穩(wěn)定的版本,體現(xiàn)在這些地方
創(chuàng)新互聯(lián)公司是專(zhuān)業(yè)的龍灣網(wǎng)站建設(shè)公司,龍灣接單;提供成都網(wǎng)站制作、成都網(wǎng)站建設(shè),網(wǎng)頁(yè)設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專(zhuān)業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行龍灣網(wǎng)站開(kāi)發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專(zhuān)業(yè)做搜索引擎喜愛(ài)的網(wǎng)站,專(zhuān)業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來(lái)合作!
工具:org.apache.poi
使用前必須了解這些:
1、要解析,那肯定先判斷是不是Excel
2、xls后綴的Excel,是03版及以前的用HSSFWorkbook類(lèi)
xlsx后綴的Excel,是07版及以后的用XSSFWorkbook解析
3、getWorkbook這個(gè)方法是我自己亂造各種Excel數(shù)據(jù)不斷測(cè)試搜索修正得出的結(jié)果,其他的像簡(jiǎn)單的判斷后綴xls還是xlsx來(lái)決定用HSSH還是XSSF是不保險(xiǎn)的,比如你可能沒(méi)遇過(guò)org.apache.poi.openxml4j.exceptions.InvalidFormatException這樣的異常,當(dāng)然這個(gè)異常仍然是因?yàn)镋xcel類(lèi)型導(dǎo)致獲取workbook時(shí)出錯(cuò),然而我查到的結(jié)果是,Excel最底層是xml實(shí)現(xiàn)的,類(lèi)型問(wèn)題出在這兒,看異常的描述也可以稍微看出來(lái)openxml4j.exceptions
4 、可能出現(xiàn)空行,空的單元格,或者單元格值為空的情況,這些情況,在我的readExcel()方法里都考慮到了,為什么我不用迭代器,或者加強(qiáng)的for each循環(huán)?就是因?yàn)檫@些坑爹的空單元格或者空行啊,迭代器內(nèi)部在取cell單元格對(duì)象時(shí)跳過(guò)這些空的對(duì)象,who knows why?我也不知道,反正我測(cè)試過(guò),跳過(guò)去了,本來(lái)5個(gè)單元格,一個(gè)空的,結(jié)果就只得到4個(gè)數(shù)據(jù),即使用cell.isEmpty()和cell!=null來(lái)判斷,也沒(méi)卵用,因?yàn)楸闅v的時(shí)候直接跳過(guò)去了,都沒(méi)有判斷的機(jī)會(huì)
5、取單元格數(shù)據(jù),這個(gè)就比較簡(jiǎn)單了,判斷單元格類(lèi)型,根據(jù)類(lèi)型做相應(yīng)的處理取出來(lái),但是我覺(jué)得我這個(gè)getCellValue()的方法應(yīng)該有漏洞,先這么用著
下面上代碼,簡(jiǎn)單描述下關(guān)鍵部位
import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; import java.io.InputStream; import java.io.PushbackInputStream; import java.util.ArrayList; import java.util.HashMap; import java.util.Map; import java.util.List; import org.apache.poi.POIXMLDocument; import org.apache.poi.openxml4j.exceptions.InvalidFormatException; import org.apache.poi.openxml4j.opc.OPCPackage; import org.apache.poi.poifs.filesystem.POIFSFileSystem; import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet; import org.apache.poi.ss.usermodel.Workbook; import org.apache.poi.xssf.usermodel.XSSFWorkbook; import org.apache.poi.hssf.usermodel.HSSFCell; import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.apache.xmlbeans.impl.piccolo.io.FileFormatException; /** *yanbiao 2016.10.25 */ public class ExcelUtil { private static final String EXTENSION_XLS = "xls"; private static final String EXTENSION_XLSX = "xlsx"; /** * 文件檢查 */ private void preReadCheck(String filePath) throws FileNotFoundException, FileFormatException { File file = new File(filePath); if (!file.exists()) { throw new FileNotFoundException("導(dǎo)入的文件不存在:" + filePath); } if (!(filePath.endsWith(EXTENSION_XLS) || filePath.endsWith(EXTENSION_XLSX))) { throw new FileFormatException("傳入的文件不是excel"); } } /** * 取得WorkBook對(duì)象 * xls:HSSFWorkbook,03版 * xlsx:XSSFWorkbook,07版 */ private Workbook getWorkbook(String filePath) throws IOException, InvalidFormatException { //直接判斷后綴來(lái)返回相應(yīng)的Workbook對(duì)象多數(shù)情況沒(méi)問(wèn)題,但是這個(gè)更保險(xiǎn),第3條已經(jīng)說(shuō)明 Workbook wb = null; InputStream is = new FileInputStream(filePath); if (!is.markSupported()) { is = new PushbackInputStream(is, 8); } if (POIFSFileSystem.hasPOIFSHeader(is)) { return new HSSFWorkbook(is); } if (POIXMLDocument.hasOOXMLHeader(is)) { return new XSSFWorkbook(OPCPackage.open(is)); } throw new IllegalArgumentException("您的excel版本目前不支持poi解析"); } /** * 讀取excel文件內(nèi)容 */ public Map<Integer, List<String>> readExcel(String filePath) throws FileNotFoundException, FileFormatException { // 檢查和獲取workbook對(duì)象 this.preReadCheck(filePath); Workbook wb = null; Map<Integer,List<String>> map = new HashMap<Integer, List<String>>(); try { wb = this.getWorkbook(filePath); // 默認(rèn)只讀取第一個(gè)sheet Sheet sheet = wb.getSheetAt(0); int rowcount = sheet.getLastRowNum();//邏輯行,包括空行 int cellcount = sheet.getRow(0).getLastCellNum();//第一行(將來(lái)作為字段的行)有多少個(gè)單元格 for (int i=0;i<rowcount;i++) { //這里用最原始的for循環(huán)來(lái)保證每行都會(huì)被讀取 List<String> list = new ArrayList<String>(); Row row = sheet.getRow(i); if(null!=row){ for (int j=0;j<cellcount;j++) { list.add(getCellValue(row.getCell(j))); //這里也是用for循環(huán),用Cell c:row這樣的遍歷,空單元格就被拋棄了 } System.out.println("第"+(row.getRowNum()+1)+"行數(shù)據(jù):"+list.toString()); map.put(row.getRowNum(), list); }else{ for (int j=0;j<cellcount;j++) { list.add("無(wú)數(shù)據(jù)"); } System.out.println("第"+(i+1)+"行數(shù)據(jù):"+list.toString()); map.put(i, list); } } } catch (Exception e) { System.out.println("讀取Excel異常:"+e.getMessage()); e.printStackTrace(); } finally { if (wb != null) { try { wb.close(); } catch (IOException e) { e.printStackTrace(); } } } return map; } /** * 取單元格的值 */ private String getCellValue(Cell c) { if (c == null) { return "無(wú)數(shù)據(jù)"; } String value = ""; switch (c.getCellType()){ case HSSFCell.CELL_TYPE_NUMERIC://數(shù)字 value = c.getNumericCellValue()+""; break; case HSSFCell.CELL_TYPE_STRING://字符串 value = c.getStringCellValue(); break; case HSSFCell.CELL_TYPE_BOOLEAN://boolean value = c.getBooleanCellValue()+""; break; case HSSFCell.CELL_TYPE_FORMULA://公式 value = c.getCellFormula()+""; break; case HSSFCell.CELL_TYPE_BLANK://空值 value= "無(wú)數(shù)據(jù)"; break; case HSSFCell.CELL_TYPE_ERROR: value = "非法字符"; break; default: value= "未知類(lèi)型"; break; } return value; } }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。
網(wǎng)頁(yè)題目:java如何讀取Excel簡(jiǎn)單模板
文章URL:http://muchs.cn/article12/pdhhgc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)、移動(dòng)網(wǎng)站建設(shè)、網(wǎng)站改版、ChatGPT、網(wǎng)站導(dǎo)航、自適應(yīng)網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)