
import javaioFileOutputStream;
import orgapachepoihssfusermodelHSSFCell;
import orgapachepoihssfusermodelHSSFCellStyle;
import orgapachepoihssfusermodelHSSFFont;
import orgapachepoihssfusermodelHSSFRow;
import orgapachepoihssfusermodelHSSFSheet;
import orgapachepoihssfusermodelHSSFWorkbook;
import orgapachepoihssfusermodelHSSFRichTextString;
import orgapachepoihssfusermodelHSSFDataFormat;
import orgapachepoihssfusermodelHSSFComment;
import orgapachepoihssfusermodelHSSFPatriarch;
import orgapachepoihssfusermodelHSSFClientAnchor;
public class PoiCreateExcelTest {
public static void main(String[] args) {
/
@see <a href=">
按列读取的方法:
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());
}
}
}
}
}
}
注意事项:同样写入到Excel的时间格式为------> yyyy/m/d h:mm:ss ,且单元格宽度不够的的情况的下:
显示方式1:
显示方式2:
原因分析:“显示方式1”的写入格式是String类型,cellsetCellValue(date),其中date为String类型;
“显示方式2”的写入格式为Date类型,cellsetCellValue(date),其中date为Date类型;
解决办法:
1如果想要时间格式不被压缩成成“###”,可以将我们获取到的时间转换成String类型,
SimpleDateFormat formatter= new SimpleDateFormat("yyyy/M/d H:mm:ss");
Date date= new Date(SystemcurrentTimeMillis());
String time= formatterformat(date);
2如果想要单元格格式为时间,且在单元格宽度不够的情况下显示成“###” ,
CreationHelper createHelper=workbookgetCreationHelper();
CellStyle style= workbookcreateCellStyle();
DataFormat format= workbookcreateDataFormat();
stylesetDataFormat(createHelpercreateDataFormat()getFormat("yyyy/M/d H:mm:ss"));
cellsetCellValue(new Date());
cellsetCellStyle(style);
即可!
备注:将时间字符串timeString转换成Date格式方法:
Date date=null;
SimpleDateFormat formatter=new SimpleDateFormat("yyyy/M/d H:mm:ss");
date=formatterparse(timeString);
以上。
以上就是关于java 导出excel 怎样设置单元格宽度自适应全部的内容,包括:java 导出excel 怎样设置单元格宽度自适应、利用POI技术从数据库里提取数据,生成一个Excel文档或者Word文档、Java POI读取Excel的时候怎么按列读取等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)