要用Java POI读取Excel文件中的数据,并且实现对数据的格式校验,输入错误信息

要用Java POI读取Excel文件中的数据,并且实现对数据的格式校验,输入错误信息,第1张

<pre t="code" l="java">// 以下为我在项目中运用的jxl的核心代码

try {

Workbook book = null;

book = WorkbookgetWorkbook(file);

// 获得第一个工作表对象

Sheet sheet = bookgetSheet(0);

int rows = sheetgetRows();

if(rows>1){

Map idnomap = thisgetStudentByIdnos(sheet);

for (int j = 1; j < sheetgetRows(); j++) {// 得到的是行的单元格

TStudentinfo stu = thisgetStudent(sheet,sheetgetRow(j),rows,j,appmap,classmap,idnomap,state);

if(stu==null){

continue;

}

stulistadd(stu);

}

}

bookclose();

// DEMO: db *** 作在下方

xxxServiceadd(stulist);

}

catch (Exception e) {

Systemoutprintln(e);

}

按列读取的方法:

String pathname = "E:\\files\\titlexlsx";

File file = new File(pathname);

InputStream in = new FileInputStream(file);

//得到整个excel对象

XSSFWorkbook excel = new XSSFWorkbook(in);

//获取整个excel有多少个sheet

int sheets = excelgetNumberOfSheets();

//便利第一个sheet

Map<String,String> colMap = new HashMap<String, String>();

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

XSSFSheet sheet = excelgetSheetAt(i);

if(sheet == null){

continue;

}

int mergedRegions = sheetgetNumMergedRegions();

XSSFRow row2 = sheetgetRow(0);

Map<Integer,String> category = new HashMap<Integer, String>();

for(int j = 0 ; j < mergedRegions; j++ ){

CellRangeAddress rangeAddress = sheetgetMergedRegion(j);

int firstRow = rangeAddressgetFirstColumn();

int lastRow = rangeAddressgetLastColumn();

categoryput(rangeAddressgetFirstColumn(), rangeAddressgetLastColumn()+"-"+row2getCell(firstRow)toString());

}

//便利每一行

for( int rowNum = 1 ; rowNum <= sheetgetLastRowNum() ; rowNum++ ){

Systemoutprintln();

XSSFRow row = sheetgetRow(rowNum);

if(row == null){

continue;

}

short lastCellNum = rowgetLastCellNum();

String cate = "";

Integer maxIndex = 0;

for( int col = rowgetFirstCellNum() ; col < lastCellNum ; col++ ){

XSSFCell cell = rowgetCell(col);

if(cell == null ){

continue;

}

if(""equals(celltoString())){

continue;

}

int columnIndex = cellgetColumnIndex();

String string = categoryget(columnIndex);

if(string != null && !stringequals("")){

String[] split = stringsplit("-");

cate = split[1];

maxIndex = IntegerparseInt(split[0]);

Systemoutprintln(cate+"<-->"+celltoString());

}else {

//如果当前便利的列编号小于等于合并单元格的结束,说明分类还是上面的分类名称

if(columnIndex<=maxIndex){

Systemoutprintln(cate+"<-->"+celltoString());

}else {

Systemoutprintln("分类未知"+"<-->"+celltoString());

}

}

}

}

}

}

1、实现日期格式的方法代码。

2、实现保留三位小数格式的方法代码。

3、实现货币格式的方法代码。

4、实现百分比格式的方法代码。

4、实现中文大写格式的方法代码。

注意事项:

Excel虽然提供了大量的用户界面特性,但它仍然保留了第一款电子制表软件VisiCalc的特性:行、列组成单元格,数据、与数据相关的公式或者对其他单元格的绝对引用保存在单元格中。

api里面好像没有直接按列读取的方法,变通一下吧。根据自己需要的列的数量分别按列建立存储的数据结构(List),然后使用API迭代行,每一次迭代把每一行需要的列数据存入已经建立的数据结构。这样的话一次循环就可以得所有的列数据了。

以上就是关于要用Java POI读取Excel文件中的数据,并且实现对数据的格式校验,输入错误信息全部的内容,包括:要用Java POI读取Excel文件中的数据,并且实现对数据的格式校验,输入错误信息、Java POI读取Excel的时候怎么按列读取、poi读取Excel时,如果单元格设置的是数字格式,如何解决整数与小数问题等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

原文地址: http://outofmemory.cn/web/10101164.html

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

发表评论

登录后才能评论

评论列表(0条)

保存