java 导出excel 怎样设置单元格宽度自适应

java 导出excel 怎样设置单元格宽度自适应,第1张

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的时候怎么按列读取等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

原文地址:https://54852.com/web/9436110.html

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

发表评论

登录后才能评论

评论列表(0条)

    保存