poi导入excel

poi导入excel,第1张

方法/步骤

一,  ExcelUtils 工具类(也就是解析EXCEL文件,判断EXCEL的类型以及数据的类型)

import  javaioIOException;

import  javaioInputStream;

import  javamathBigDecimal;

import  javatextSimpleDateFormat;

import  javautilArrayList;

import  javautilDate;

import  javautilList;

import  orgapachepoihssfusermodelHSSFDateUtil;

import  orgapachepoihssfusermodelHSSFWorkbook;

import  orgapachepoissusermodelCell;

import  orgapachepoissusermodelRow;

import  orgapachepoissusermodelSheet;

import  orgapachepoissusermodelWorkbook;

import  orgapachepoixssfusermodelXSSFWorkbook;

public class ExcelUtils {

private final static  String excel2003L = “xls” ;    // 2003-版本的excel

private final static  String excel2007U = “xlsx” ;   // 2007 +版本的excel

/

描述:获取IO流中的数据,组装成List <List <Object>对象

@param in,fileName

@返回

@throws IOException

/

public   List <List <Object> getBankListByExcel(InputStream in,String fileName)  throws  Exception {

列表<List <Object> list =  null ;

//创建的Excel工作薄

Workbook work =  this getWorkbook(in,fileName);

if (null  == work){

抛出新的 异常(“创建Excel工作薄为空!” );

}

Sheet sheet =  null ;  //页数

行row =  null ;  //行数

Cell cell =  null ;  //列数

list =  new  ArrayList <List <Object >>();

//遍历的Excel中所有的片

for  (int  i =  0 ; i <workgetNumberOfSheets(); i ++){

sheet = workgetSheetAt(i);

if (sheet == null ){ continue ;}

//遍历当前片中的所有行

for  (int  j = sheetgetFirstRowNum(); j <= sheetgetLastRowNum(); j ++){

row = sheetgetRow(j);

if (row == null || rowgetFirstCellNum()== j){ continue ;}

//遍历所有的列

列表<Object> li =  new  ArrayList <Object>();

for  (int  y = rowgetFirstCellNum(); y <rowgetLastCellNum(); y ++){

cell = rowgetCell(y);

liadd(this getValue(cell));

}

listadd(LI);

}

}

return 单

}

/

描述:根据文件后缀,自适应上传文件的版本

@param inStr,fileName

@返回

@throws异常

/

public   Workbook getWorkbook(InputStream inStr,String fileName)  throws  Exception {

工作簿wb =  null ;

String fileType = fileNamesubstring(fileNamelastIndexOf(“。” ));

if (excel2003Lequals(fileType)){

wb =  new  HSSFWorkbook(inStr);  // 2003-

} else if (excel2007Uequals(fileType)){

wb =  new  XSSFWorkbook(inStr);  // 2007 +

} else {

抛出新的 异常(“解析的文件格式有误!” );

}

返回 wb;

}

/

描述:对表格中数值进行格式化

@param单元格

@返回

/

//解决擅长类型问题,获得数值

public   String getValue(Cell cell){

String value =  “” ;

if (null == cell){

返回 值

}

switch  (cellgetCellType()){

//数值型

案例 CellCELL_TYPE_NUMERIC:

if  (HSSFDateUtilisCellDateFormatted(cell)){

//如果是date类型则,获取该单元格的日期值

Date date = HSSFDateUtilgetJavaDate(cellgetNumericCellValue());

SimpleDateFormat format =  new  SimpleDateFormat(“yyyy-MM-dd” );

value = formatformat(date);;

} else  { //纯数字

BigDecimal big = new  BigDecimal(cellgetNumericCellValue());

value = bigtoString();

//解决12340去掉后面的0

if (null != value &&!“” equals(valuetrim())){

String [] item = valuesplit(“[。]” );

if (1 <itemlength && “0” equals(item [ 1 ])){

value = item [ 0 ];

}

}

}

break;

//字符串类型

案例 CellCELL_TYPE_STRING:

value = cellgetStringCellValue()。toString();

break;

//公式类型

案例 CellCELL_TYPE_FORMULA:

//读公式计算值

value = StringvalueOf(cellgetNumericCellValue());

if  (valueequals(“NaN” )){ //如果获取的数据值为非法值,则转换为获取字符串

value = cellgetStringCellValue()。toString();

}

break;

//布尔类型

案例 CellCELL_TYPE_BOOLEAN:

value =  “” + cellgetBooleanCellValue();

break;

默认值:

value = cellgetStringCellValue()。toString();

}

if (“null” endsWith(valuetrim())){

value = “” ;

}

返回 值

}

}

二,定义两个实体类,一个是对于的Excel文件,解析它的数据(ExcelBean),另一个是导入数据库表的实体类(人)

ExcelBeanjava

<strong> <span style = “font-size:18px;” > import  orgapachepoixssfusermodelXSSFCellStyle;

公共类 ExcelBean  实现 javaioSerializable {

private  String headTextName; //列头(标题)名

private  String propertyName; //对应字段名

私有 整数列; //合并单元格数

私人 XSSFCellStyle cellStyle;

public  ExcelBean(){

}

public  ExcelBean(String headTextName,String propertyName){

这个headTextName = headTextName;

这个propertyName = propertyName;

}

public  ExcelBean(String headTextName,String propertyName,Integer cols){

super ();

这个headTextName = headTextName;

这个propertyName = propertyName;

这个cols = cols;

}

public  String getHeadTextName(){

return  headTextName;

}

public void  setHeadTextName(String headTextName){

这个headTextName = headTextName;

}

public  String getPropertyName(){

return  propertyName;

}

public void  setPropertyName(String propertyName){

这个propertyName = propertyName;

}

public  Integer getCols(){

返回列 ;

}

公共无效   setCols(Integer cols){

这个cols = cols;

}

上市  XSSFCellStyle getCellStyle(){

返回  cellStyle;

}

公共无效   setCellStyle(XSSFCellStyle cellStyle){

这个 cellStyle = cellStyle;

}

} </ span> </ strong>

peoplejava

import  javautilDate;

公共课 人

私有 整数id

private  String userName;

私人 字符串密码;

私人 整数年龄;

私人 日期;

public  Integer getId(){

返回  id

}

public void  setId(Integer id){

这个id = id;

}

public  String getUserName(){

return  userName;

}

public void  setUserName(String userName){

这个userName = userName ==  null  ? null  :userNametrim();

}

public  String getPassword(){

返回 密码

}

public void  setPassword(String password){

这个password = password ==  null  ? null  :passwordtrim();

}

public  Integer getAge(){

回归 年龄

}

public void  setAge(Integer age){

这个age = age

}

public  Date getDate(){

退货 日期

}

public void  setDate(Date date){

这个date = date

}

}

stackoverflow上有这个问题的答案

这里我引用一下:

var workbook = new XSSFWorkbook(stream);

var sheet = workbookGetSheetAt(0);

var cr = new CellReference("D5");//这里填位置

var row = sheetGetRow(crRow);

var cell = rowGetCell(crCol);

ConsoleWrite(cellStringCellValue);

可以直接用坐标索引读取,即:

例如,A是一个元胞数组

那么A{i,j}(m,n)表示:

元胞第i行j列矩阵的第m行第n列

调整内容:添加和删除与普通矩阵方法一致

相关函数:celldisp:显示所有的内容

cell:创建空的元胞数组

cellplot:利用图形方式显示内容

cell2mat:将数组转变成为普通的矩阵

mat2cell:将数值矩阵转变成为cell数组

num2cell:将数值数组转变成为cell数组

cell2struct:将数组转变成为结构

struct2cell:将结构转变为cell数组

iscell:判断输入是否为cell数组

cellfun:为cell数组的每个cell执行指定的函数 fun可以是特殊函数或者句柄

首先POI是开源组织Apache出品的一个开源jar包,提供了方便解析Excel的API,我们可以非常方便的使用它来读取Excel。这里介绍35Final版本。

所需用到的jar包如下:

说到Excel,有2003和2007,格式是不一样的,用POI解析的方法也就不一样,Excel2003主要是使用orgapachepoihssfusermodel包中的类来解析,而Excel2007就是使用orgapachepoixssfusermodel来解析。

解析Excel2003源码

说到Excel,有2003和2007,格式是不一样的,用POI解析的方法也就不一样,Excel2003主要是使用orgapachepoihssfusermodel包中的类来解析,而Excel2007就是使用orgapachepoixssfusermodel来解析。

解析Excel2003源码

StringBuffer content = new StringBuffer();

  HSSFWorkbook workbook = new HSSFWorkbook(is); // 创建对Excel工作簿文件的引用

for (int numSheets = 0; numSheets < workbookgetNumberOfSheets(); numSheets++) {

   if (null != workbookgetSheetAt(numSheets)) {

    HSSFSheet aSheet = workbookgetSheetAt(numSheets); // 获得一个sheet

for (int rowNumOfSheet = 0; rowNumOfSheet <= aSheetgetLastRowNum(); rowNumOfSheet++) {

     if (null != aSheetgetRow(rowNumOfSheet)) {

      HSSFRow aRow = aSheetgetRow(rowNumOfSheet); // 获得一行

for (int cellNumOfRow = 0; cellNumOfRow <= aRowgetLastCellNum(); cellNumOfRow++) {

       if (null != aRowgetCell(cellNumOfRow)) {

        HSSFCell aCell = aRowgetCell(cellNumOfRow); // 获得列值

        

        if (aCellgetCellType() == HSSFCellCELL_TYPE_NUMERIC) {

         contentappend(aCellgetNumericCellValue() + "\t");

        } else if (aCellgetCellType() == HSSFCellCELL_TYPE_BOOLEAN) {

         contentappend(aCellgetBooleanCellValue() + "\t");

        } else if (aCellgetCellType() == HSSFCellCELL_TYPE_STRING) {

         contentappend(aCellgetStringCellValue() + "\t");

        } else if (aCellgetCellType() == HSSFCellCELL_TYPE_FORMULA){

         contentappend(aCellgetCellFormula() + "\t");

        } else {

         continue;

        }

       }

       if(cellNumOfRow == aRowgetLastCellNum()) {

        contentappend("\n");

       }

      }

     }

    }

   }

  }

return contenttoString()trim();

解析Excel2007和2003基本一样,只是将HSSFSheet,HSSFCell等都改成XSSFSheet,XSSFCell即可。

另外要提醒大家的是Excel的样式都是基于一个单元格的,所以用HSSFRowgetRowStyle()拿样式会出问题的,不一定会拿到你想要的样式。处理合并单元格是POI的一个难点,只能通过判断当前单元格是否在合并单元格之中,如果是,那此单元格的值便是这个合并单元格的首位置单元格的值,只有通过这样才能来处理合并单元格。

处理合并单元格的代码:

 public static boolean isMergedRegion(HSSFSheet sheet, HSSFCell cell) {

  //得到一个sheet中有多少个合并单元格

  int sheetmergerCount = sheetgetNumMergedRegions();

  for(int i = 0; i < sheetmergerCount; i++) {

   //得出具体的合并单元格

   CellRangeAddress ca = sheetgetMergedRegion(i);

   //得到合并单元格的起始行, 结束行, 起始列, 结束列

   int firstC = cagetFirstColumn();

   int lastC = cagetLastColumn();

   int firstR = cagetFirstRow();

   int lastR = cagetLastRow();

   //判断该单元格是否在合并单元格范围之内, 如果是, 则返回 true

   if(cellgetColumnIndex() <= lastC && cellgetColumnIndex() >= firstC) {

    if(cellgetRowIndex() <= lastR && cellgetRowIndex() >= firstR) {

     return true;

    }

   }

  }

  return false;

 }

 public static String getMergedRegionValue(HSSFSheet sheet, HSSFCell cell) {

  //获得一个 sheet 中合并单元格的数量

  int sheetmergerCount = sheetgetNumMergedRegions();

  //便利合并单元格

  for(int i = 0; i < sheetmergerCount; i++) {

   //获得合并单元格

   CellRangeAddress ca = sheetgetMergedRegion(i);

   //获得合并单元格的起始行, 结束行, 起始列, 结束列

   int firstC = cagetFirstColumn();

   int lastC = cagetLastColumn();

   int firstR = cagetFirstRow();

   int lastR = cagetLastRow();

   //判断该单元格是否是在合并单元格中, 如果是, 则返回所在合并单元格的首单元格的值

   if(cellgetColumnIndex() <= lastC && cellgetColumnIndex() >= firstC) {

    if(cellgetRowIndex() <= lastR && cellgetRowIndex() >= firstR) {

     HSSFRow fRow = sheetgetRow(firstR);

     HSSFCell fCell = fRowgetCell(firstC);

     //除了合并单元格首单元格的值, 其余的用()来区分

     if (fCellgetCellType() == HSSFCellCELL_TYPE_NUMERIC && hasBorder(cell)) {

      return StringvalueOf(fCellgetNumericCellValue());

     } else if (fCellgetCellType() == HSSFCellCELL_TYPE_BOOLEAN && hasBorder(cell)) {

      return StringvalueOf(fCellgetBooleanCellValue());

     } else if (fCellgetCellType() == HSSFCellCELL_TYPE_STRING && hasBorder(cell)) {

      return fCellgetStringCellValue();

     } else if (fCellgetCellType() == HSSFCellCELL_TYPE_FORMULA && hasBorder(cell)){

      return StringvalueOf(fCellgetCellFormula());

     }

    }

   }

  }

  return "";

 }

if(cellgetCachedFormulaResultType() == 0){res = StringvalueOf(cellgetNumericCellValue());};

if(cellgetCachedFormulaResultType() == 1){res = cellgetStringCellValue();}

不用evaluator

应该是拿倒cell的值吧,

String path="/uploadfile/download/resCheckxlsx";

XSSFWorkbook wb = new XSSFWorkbook(path);

XSSFSheet sheet = wbgetSheetAt(0);

String valueTest = sheetgetRow(0)getCell(0)getCellValue();

以上就是关于poi导入excel全部的内容,包括:poi导入excel、C#NPOI怎么获某一个单元格的值,比如获取B2位置的值,怎么写、如何读取MATLAB的CELL类型数据中的值等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/web/10099398.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-05
下一篇 2023-05-05

发表评论

登录后才能评论

评论列表(0条)

保存