日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

JavaExcel工具类(兼容xls和xlsx)

發布時間:2025/3/12 java 52 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JavaExcel工具类(兼容xls和xlsx) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

最近用上了導入excel表格處理保存到后臺數據庫的功能!利用的是org.apache.poi進行處理

示例代碼:

import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.apache.poi.ss.usermodel.*; import org.apache.poi.xssf.usermodel.XSSFWorkbook;import java.io.IOException; import java.io.InputStream; import java.text.DecimalFormat; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Date; import java.util.List;/*** Created by LiYangYong on 2022/02/06*/ public class ExcelUtil {private final static String excel2003L =".xls"; //2003- 版本的excelprivate final static String excel2007U =".xlsx"; //2007+ 版本的excel/*** 描述:獲取IO流中的數據,組裝成List<List<Object>>對象* @param in,fileName* @return* @throws IOException*/public static List<List<Object>> getBankListByExcel(InputStream in, String fileName) throws Exception{List<List<Object>> list = null;//創建Excel工作薄Workbook work = getWorkbook(in,fileName);if(null == work){throw new Exception("創建Excel工作薄為空!");}Sheet sheet = null;Row row = null;Cell cell = null;list = new ArrayList<List<Object>>();//遍歷Excel中所有的sheetfor (int i = 0; i < work.getNumberOfSheets(); i++) {sheet = work.getSheetAt(i);if(sheet==null){continue;}//遍歷當前sheet中的所有行for (int j = sheet.getFirstRowNum()+1; j < sheet.getLastRowNum()+1; j++) {row = sheet.getRow(j);if(row==null){continue;}// if(row==null||row.getFirstCellNum()==j){continue;}//遍歷所有的列List<Object> li = new ArrayList<Object>();for (int y = row.getFirstCellNum(); y < row.getLastCellNum(); y++) {cell = row.getCell(y);li.add(getCellValue(cell));}list.add(li);}}//work.close();return list;}/*** 描述:根據文件后綴,自適應上傳文件的版本* @param inStr,fileName* @return* @throws Exception*/public static Workbook getWorkbook(InputStream inStr,String fileName) throws Exception{Workbook wb = null;String fileType = fileName.substring(fileName.lastIndexOf("."));if(excel2003L.equals(fileType)){wb = new HSSFWorkbook(inStr); //2003-}else if(excel2007U.equals(fileType)){wb = new XSSFWorkbook(inStr); //2007+}else{throw new Exception("解析的文件格式有誤!");}return wb;}/*** 描述:對表格中數值進行格式化* @param cell* @return*/public static Object getCellValue2(Cell cell){Object value = null;DecimalFormat df = new DecimalFormat("0"); //格式化number String字符SimpleDateFormat sdf = new SimpleDateFormat("yyy-MM-dd"); //日期格式化DecimalFormat df2 = new DecimalFormat("0.00"); //格式化數字switch (cell.getCellType()) {case Cell.CELL_TYPE_STRING:value = cell.getRichStringCellValue().getString();break;case Cell.CELL_TYPE_NUMERIC:if("General".equals(cell.getCellStyle().getDataFormatString())){value = df.format(cell.getNumericCellValue());}else if("m/d/yy".equals(cell.getCellStyle().getDataFormatString())){value = sdf.format(cell.getDateCellValue());}else{value = df2.format(cell.getNumericCellValue());}break;case Cell.CELL_TYPE_BOOLEAN:value = cell.getBooleanCellValue();break;case Cell.CELL_TYPE_BLANK:value = "";break;default:break;}return value;}@SuppressWarnings("deprecation")public static String getCellValue(Cell cell) {if (cell == null)return "";if (cell.getCellType() == Cell.CELL_TYPE_STRING) {return cell.getStringCellValue();} else if (cell.getCellType() == Cell.CELL_TYPE_BOOLEAN) {return String.valueOf(cell.getBooleanCellValue());} else if (cell.getCellType() == Cell.CELL_TYPE_FORMULA) {return cell.getCellFormula();} else if (cell.getCellType() == Cell.CELL_TYPE_NUMERIC) {short format = cell.getCellStyle().getDataFormat();System.out.println("format:"+format+";;;;;value:"+cell.getNumericCellValue());SimpleDateFormat sdf = null;if (format == 14 || format == 31 || format == 57 || format == 58|| (176<=format && format<=178) || (182<=format && format<=196)|| (210<=format && format<=213) || (208==format ) ) { // 日期sdf = new SimpleDateFormat("yyyy-MM-dd");} else if (format == 20 || format == 32 || format==183 || (200<=format && format<=209) ) { // 時間sdf = new SimpleDateFormat("HH:mm");} else { // 不是日期格式return String.valueOf(cell.getNumericCellValue());}double value = cell.getNumericCellValue();Date date = DateUtil.getJavaDate(value);if(date==null || "".equals(date)){return "";}String result="";try {result = sdf.format(date);} catch (Exception e) {e.printStackTrace();return "";}return result;}return "";} }

大家點贊、收藏、關注、評論啦 、查看下方👇🏻👇🏻👇🏻微信公眾號獲取👇🏻👇🏻👇🏻

打卡 文章 更新?186/ ?365天

專欄推薦閱讀:

java項目精品實戰案例《100套》

web前端期末大作業網頁實戰《100套》

總結

以上是生活随笔為你收集整理的JavaExcel工具类(兼容xls和xlsx)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 亚洲日本视频 | 伊人99re| 午夜整容室 | 日韩精品视频观看 | 欧美激情综合网 | 久久无码专区国产精品s | 波多野结衣一二三四区 | 免费在线观看一区二区三区 | 91亚洲专区| 欧美精品一线 | 国产白拍| 欧美日韩三级在线 | 久久久久中文字幕亚洲精品 | 中文字幕在线视频一区二区三区 | 国产区在线 | 麻豆啪啪| av男人的天堂在线观看 | 午夜性福利视频 | 国产高清精品在线观看 | 亚洲人免费 | 日日日操操操 | 日韩激情小说 | 上原亚衣在线 | 国产午夜精品视频 | 亚洲精品男人天堂 | 国产偷人爽久久久久久老妇app | 四虎国产精品永久免费观看视频 | av在线毛片 | 可以免费看毛片的网站 | 男女av| 国产精品美女www爽爽爽视频 | 久久久久久天堂 | 婷婷五月色综合 | 免费色av| 探花精品| 丰满少妇一区二区三区 | 超黄网站在线观看 | 欧美私人网站 | 精品国产一区二区三区性色av | 殴美性生活 | 亚洲精品一区二三区不卡 | 毛片网在线 | 又黄又爽的网站 | fc2成人免费视频 | 午夜理伦三级做爰电影 | 狼友视频国产精品 | 国产无遮挡又黄又爽免费网站 | 女人裸体又黄 | 黄色小说网站在线观看 | 精品人妻无码一区 | 在线资源站 | 超碰成人在线免费观看 | 天天躁日日躁狠狠躁喷水 | 色人综合 | 日本午夜免费 | 少妇一夜三次一区二区 | 黄色av一区二区 | 97超碰人人看| 九九精品视频在线 | 黄色污污网站 | 久操精品在线 | 国产片一区二区 | 久久精品无码中文字幕 | 欧美精品第一页 | 亚洲国产日韩在线 | 一区二区麻豆 | 视色av| 二区三区视频 | 毛片3| 99re国产精品 | 冲田杏梨一区二区三区 | 三级爱爱 | 女女同性女同一区二区三区九色 | 爱色成人网 | 6—12呦国产精品 | 亚洲av永久无码精品一区二区国产 | 欧美激情性做爰免费视频 | 久久三级精品 | 国产人妻人伦精品1国产盗摄 | 国产午夜精品一区 | 欧美放荡性医生videos | 日批毛片 | 在线中文字幕第一页 | 人妻偷人精品一区二区三区 | 非洲黑寡妇性猛交视频 | 日韩亚洲国产精品 | jzzijzzij亚洲成熟少妇在线观看 久久久精品人妻一区二区三区 | 美女av影院 | 国产不卡在线观看视频 | 日韩精品一区二区亚洲av性色 | av网站在线免费观看 | 精品伦理一区二区 | 国产精品久久999 | 国产熟妇另类久久久久 | 美女视频黄色 | 成人h动漫精品一区二 | 国产av自拍一区 | 禁止18在线观看 | 国产午夜福利片 |