欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java讀取簡單excel通用工具類

 更新時間:2020年12月31日 10:31:14   作者:似水流年風(fēng)蕭兮  
這篇文章主要為大家詳細(xì)介紹了java讀取簡單excel通用工具類,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了java讀取簡單excel通用工具類的具體代碼,供大家參考,具體內(nèi)容如下

讀取excel通用工具類

import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

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.ss.usermodel.CellType;
import org.apache.poi.xssf.usermodel.XSSFCell;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;


/**
 * 讀取Excel通用工具類
 * @author zql
 */
public class ReadExcel {

 /**
 * 讀取Excel
 * 
 * @param filepath 文件路徑
 * @param filename 文件名,包括擴(kuò)展名
 * @param startrow 開始行號,索引從0開始
 * @param startcol 開始列號,索引從0開始
 * @param sheetnum 工作簿,索引從0開始
 * @return
 */
 public List<Map<String,String>> readExcel(String filepath, String filename, int startrow, int startcol, int sheetnum) {
 List<Map<String, String>> varList = new ArrayList<Map<String, String>>();
 String suffix = filename.substring(filename.lastIndexOf(".") + 1);
 if ("xls".equals(suffix)) {
 varList = readExcel2003(filepath, filename, startrow, startcol, sheetnum);
 } else if ("xlsx".equals(suffix)) {
 varList = readExcel2007(filepath, filename, startrow, startcol, sheetnum);
 } else {
 System.out.println("Only excel files with XLS or XLSX suffixes are allowed to be read!");
 return null;
 }
 return varList;
 }
 
 /**
 * 讀取2003Excel
 * 
 * @param filepath 文件路徑
 * @param filename 文件名,包括擴(kuò)展名
 * @param startrow 開始行號,索引從0開始
 * @param startcol 開始列號,索引從0開始
 * @param sheetnum 工作簿,索引從0開始
 * @return
 */
 public List<Map<String,String>> readExcel2003(String filepath, String filename, int startrow, int startcol, int sheetnum) {
 List<Map<String, String>> varList = new ArrayList<Map<String, String>>();
 try {
 File target = new File(filepath, filename);
 FileInputStream fis = new FileInputStream(target);
 HSSFWorkbook wb = new HSSFWorkbook(fis);
 fis.close();
 // sheet 從0開始
 HSSFSheet sheet = wb.getSheetAt(sheetnum);
 // 取得最后一行的行號
 int rowNum = sheet.getLastRowNum() + 1;

 HSSFRow rowTitle = sheet.getRow(0);
 // 標(biāo)題行的最后一個單元格位置
 int cellTitleNum = rowTitle.getLastCellNum();
 String[] title = new String[cellTitleNum];
 for (int i = startcol; i < cellTitleNum; i++) {
 HSSFCell cell = rowTitle.getCell(Short.parseShort(i + ""));
 if (cell != null) {
  cell.setCellType(CellType.STRING);
  title[i] = cell.getStringCellValue();
 } else {
  title[i] = "";
 }
 }

 // 行循環(huán)開始
 for (int i = startrow + 1; i < rowNum; i++) {
 Map<String, String> varpd = new HashMap<String, String>();
 // 行
 HSSFRow row = sheet.getRow(i);
 // 列循環(huán)開始
 for (int j = startcol; j < cellTitleNum; j++) {

  HSSFCell cell = row.getCell(Short.parseShort(j + ""));
  String cellValue = "";
  if (cell != null) {
  // 把類型先設(shè)置為字符串類型
  cell.setCellType(CellType.STRING);
  cellValue = cell.getStringCellValue();
  }
  varpd.put(title[j], cellValue);
 }
 varList.add(varpd);
 }
 wb.close();
 } catch (Exception e) {
 System.out.println(e);
 }
 return varList;
 }
 
 /**
 * 讀取2007Excel
 * 
 * @param filepath 文件路徑
 * @param filename 文件名,包括擴(kuò)展名
 * @param startrow 開始行號,索引從0開始
 * @param startcol 開始列號,索引從0開始
 * @param sheetnum 工作簿,索引從0開始
 * @return
 */
 public List<Map<String,String>> readExcel2007(String filepath, String filename, int startrow, int startcol, int sheetnum) {
 List<Map<String, String>> varList = new ArrayList<Map<String, String>>();
 try {
 File target = new File(filepath, filename);
 InputStream ins = new FileInputStream(target);
 XSSFWorkbook wb = new XSSFWorkbook(ins);
 ins.close();
 // 得到Excel工作表對象
 XSSFSheet sheet = wb.getSheetAt(sheetnum);
 // 取得最后一行的行號
 int rowNum = sheet.getLastRowNum() + 1;

 XSSFRow rowTitle = sheet.getRow(0);
 int cellTitleNum = rowTitle.getLastCellNum();
 String[] title = new String[cellTitleNum];
 for (int i = startcol; i < cellTitleNum; i++) {
 XSSFCell cell = rowTitle.getCell(Short.parseShort(i + ""));
 if (cell != null) {
  // 把類型先設(shè)置為字符串類型
  cell.setCellType(CellType.STRING);
  title[i] = cell.getStringCellValue();
 } else {
  title[i] = "";
 }
 }

 // 行循環(huán)開始
 for (int i = startrow + 1; i < rowNum; i++) {
 Map<String, String> varpd = new HashMap<String, String>();
 // 得到Excel工作表的行
 XSSFRow row = sheet.getRow(i);
 // 列循環(huán)開始
 for (int j = startcol; j < cellTitleNum; j++) {
  // 得到Excel工作表指定行的單元格
  XSSFCell cell = row.getCell(j);
  String cellValue = "";
  if (cell != null) {
  // 把類型先設(shè)置為字符串類型
  cell.setCellType(CellType.STRING);
  cellValue = cell.getStringCellValue();
  }
  varpd.put(title[j], cellValue);
 }
 varList.add(varpd);
 }
 wb.close();
 } catch (Exception e) {
 System.out.println(e);
 }
 return varList;
 }
 
}

讀取excel通用工具示例測試類

import java.util.List;
import java.util.Map;

/**
 * @author zql
 *
 */
public class ReadExcelTest {
 
 public static void main(String[] args) throws Exception {
 ReadExcel r = new ReadExcel();
 List<Map<String, String>> list = r.readExcel("e:\\excel", "測試表格.xls", 0, 0, 0);
 if (list != null) {
 for (int i = 0; i < list.size(); i++) {
 Map<String, String> m = list.get(i);
 m.forEach((key, value) -> {
  System.out.println(key + ":" + value);
 });
 System.out.println();
 }
 }

 List<Map<String, String>> lists = r.readExcel("e:\\excel", "測試表格.xlsx", 0, 0, 0);
 if (lists != null) {
 for (int i = 0; i < lists.size(); i++) {
 Map<String, String> m = lists.get(i);
 m.forEach((key, value) -> {
  System.out.println(key + ":" + value);
 });
 System.out.println();
 }
 }
 }

}

普通項目需要引入的包

poi-4.0.1.jar
poi-ooxml-4.0.1.jar
poi-ooxml-schemas-4.0.1.jar
commons-codec-1.11.jar
commons-collections4-4.3.jar
commons-math3-3.6.1.jar
xmlbeans-3.0.2.jar
commons-compress-1.18.jar
curvesapi-1.06.jar

maven項目依賴

<!-- poi -->
<dependency>
 <groupId>org.apache.poi</groupId>
 <artifactId>poi</artifactId>
 <version>4.0.1</version>
</dependency>
<dependency>
 <groupId>org.apache.poi</groupId>
 <artifactId>poi-ooxml</artifactId>
 <version>4.0.1</version>
</dependency>

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • SpringMVC下實現(xiàn)Excel文件上傳下載

    SpringMVC下實現(xiàn)Excel文件上傳下載

    這篇文章主要為大家詳細(xì)介紹了SpringMVC下實現(xiàn)Excel文件上傳下載,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-03-03
  • Spring控制Bean加載順序的操作方法

    Spring控制Bean加載順序的操作方法

    正常情況下,Spring 容器加載 Bean 的順序是不確定的,那么我們?nèi)绻枰错樞蚣虞d Bean 時應(yīng)如何操作?本文將詳細(xì)講述我們?nèi)绾尾拍芸刂?nbsp;Bean 的加載順序,需要的朋友可以參考下
    2024-05-05
  • 詳解SpringBoot?統(tǒng)一后端返回格式的方法

    詳解SpringBoot?統(tǒng)一后端返回格式的方法

    今天我們來聊一聊在基于SpringBoot前后端分離開發(fā)模式下,如何友好的返回統(tǒng)一的標(biāo)準(zhǔn)格式以及如何優(yōu)雅的處理全局異常,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2022-05-05
  • Java中斷異常的正確處理方法

    Java中斷異常的正確處理方法

    這篇文章主要給大家介紹了關(guān)于Java中斷異常的正確處理方法,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用Java具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • 一文搞懂java中類及static關(guān)鍵字執(zhí)行順序

    一文搞懂java中類及static關(guān)鍵字執(zhí)行順序

    這篇文章主要介紹了一文搞懂java中類及static關(guān)鍵字執(zhí)行順序,文章通過類的生命周期展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-09-09
  • 關(guān)于SpringBoot中事務(wù)失效的幾種情況

    關(guān)于SpringBoot中事務(wù)失效的幾種情況

    這篇文章主要介紹了關(guān)于SpringBoot中事務(wù)失效的幾種情況,Spring AOP默認(rèn)使用動態(tài)代理,會給被代理的類生成一個代理類,事務(wù)相關(guān)的操作都通過代理來完成,使用內(nèi)部方法調(diào)用時,使用的是實例調(diào)用,沒有通過代理類調(diào)用方法,因此事務(wù)不會檢測到失敗,需要的朋友可以參考下
    2023-08-08
  • java之左旋轉(zhuǎn)字符串介紹

    java之左旋轉(zhuǎn)字符串介紹

    java之左旋轉(zhuǎn)字符串介紹,需要的朋友可以參考一下
    2013-02-02
  • Java使用組件編寫窗口實現(xiàn)網(wǎng)絡(luò)圖片顯示

    Java使用組件編寫窗口實現(xiàn)網(wǎng)絡(luò)圖片顯示

    這篇文章主要為大家詳細(xì)介紹了Java使用組件編寫窗口實現(xiàn)網(wǎng)絡(luò)圖片顯示的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • mybatis如何根據(jù)表逆向自動化生成代碼實例

    mybatis如何根據(jù)表逆向自動化生成代碼實例

    逆向工程是一個專門為 MyBatis 框架使用者設(shè)計的代碼生成器,可以根據(jù)數(shù)據(jù)庫中的表字段名,自動生成 POJO 類,mapper 接口與 SQL 映射文件,這篇文章主要給大家介紹了關(guān)于mybatis如何根據(jù)表逆向自動化生成代碼的相關(guān)資料,需要的朋友可以參考下
    2021-08-08
  • SpringBoot入門編寫第一個程序Helloworld

    SpringBoot入門編寫第一個程序Helloworld

    這篇文章是Springboot入門篇,來教大家編寫第一個Springboot程序Helloworld,文中附有詳細(xì)的示例代碼,有需要的同學(xué)可以借鑒參考下
    2021-09-09

最新評論