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中的一行数据等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)