POI *** 作Excel,有直接获取列的方法吗

POI *** 作Excel,有直接获取列的方法吗,第1张

poi提供的 *** 作excel的方法比较基础,所以一般我在使用的时候 会自己写一个 utils, 比如 复制sheet 复制某一区域 等功能,建议LZ 用POI的时候也写这么个方法类。

1创建一个excel关联对象HSSFWorkbook:

HSSFWorkbook book = new HSSFWorkbook();

2创建一个sheet:

HSSFSheet st = bookcreateSheet("sheet1");

3创建第i行:

HSSFRow row = stcreateRow(i);

4创建第i行的j列:

HSSFCell cell = rowcreateCell(j);

5设置cell属性

单元格设置边框属性:

+ View Code

HSSFCellStyle style = bookcreateCellStyle();

// 左右上下边框样式

stylesetBorderLeft(HSSFCellStyleBORDER_THIN);

stylesetBorderRight(HSSFCellStyleBORDER_THIN);

stylesetBorderTop(HSSFCellStyleBORDER_THIN);

stylesetBorderBottom(HSSFCellStyleBORDER_THIN);

// 左右上下边框颜色(深蓝色),只有设置了上下左右边框以后给边框设置颜色才会生效

stylesetLeftBorderColor(HSSFColorBLACKindex);

stylesetRightBorderColor(HSSFColorBLACKindex);

stylesetTopBorderColor(HSSFColorBLACKindex);

stylesetBottomBorderColor(HSSFColorBLACKindex);

6给单元格设置背景:

stylesetFillPattern(HSSFCellStyleSOLID_FOREGROUND);// 设置了背景色才有效果

stylesetFillForegroundColor(HSSFColorGREY_25_PERCENTindex);

7给单元格设置字体:

// 单元格字体

HSSFFont font = bookcreateFont();

fontsetFontName("宋体");

9设置字体以后,需要把字体加入到style中:

stylesetFont(font);

10设置好单元格属性以后,需要这种属性的单元格就可以调用此style:

cellsetCellStyle(style);

11设置sheet表单的列宽:

stsetColumnWidth(i, cellWidthsget(i)intValue() 160);

12列宽的设置方法在HSSFSheet中,方法参数:第一个参数表示第几列,从0开始数;第二个参数表示宽度为多少,大小由使用者调整。

合并单元格:

staddMergedRegion(new CellRangeAddress(0, 1, 0, keyssize() - 1));

13单元格合并方法也是在HSSFSheet中,方法参数:一个CellRangeAddress,该类构造函数的4个参数分别表示为:合并开始行,合并结束行,合并开始列,合并结束列。

static public void main(String[] args){

try {

FileInputStream fis = new FileInputStream("d:\\aaxls");

HSSFWorkbook wb = new HSSFWorkbook(fis);

HSSFSheet s = wbgetSheet("Sheet1");

HSSFRow row=sgetRow(0);

HSSFCell cell=rowgetCell((short) 0);

Systemoutprintln(cellgetStringCellValue());

fisclose();

} catch (Exception e) {

eprintStackTrace();

}

}

通过getPhysicalNumberOfRows()获得的实际行数,不一定有数据的行数。

比如某个单元格只设置了非“常规”的格式,它也会被POI认为是实际行。

不过POI里似乎没有没有这样的方法,getNextPhysicalRow()。

所以只好从getFirstRowNum()到getLastRowNum()遍历,如果null==currentRow,验证下一行。

按列读取的方法:

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());

}

}

}

}

}

}

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

以上就是关于POI *** 作Excel,有直接获取列的方法吗全部的内容,包括:POI *** 作Excel,有直接获取列的方法吗、poi *** 作excel 如何循环第一列(急,大家帮帮忙)、java中使用POI如何获得EXCEL中的一行数据等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存