问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

poi操作excel表,怎么将单元格的格式设置为

发布网友 发布时间:2022-04-26 01:57

我来回答

1个回答

热心网友 时间:2022-06-19 19:02

 通过poi导出excel的过程大致是这样的:
     规定单元格的格式
        ↓
      创建单元格
        ↓
     设置单元格的格式
        ↓
     设置数据的格式
        ↓
    把数据存放到单元格中
        ↓
      通过IO流输出

背景POI导出Excel时设置单元格类型为数值类型
  要想存放数值的单元格以数值类型导出,其中最关键的步骤就是上面加粗的两步,设置单元格的格式和向单元格中存放数据。
  核心代码如下:
/**
* 导出Excel-胡玉洋-2015年11月11日
*
*@param outPutParam Excel数据实体,包括要导出的excel标头、列标题、数据等
* */
private void createContentRows(ExcelParam outPutParam) {
HSSFWorkbook workbook=new HSSFWorkbook(); //创建一个Excel文件
// 遍历集合数据,产生数据行
for (int i = 0; i < outPutParam.getContent().size(); i++) {
int rowIndex = i + 2;
HSSFRow contentRow = sheet.createRow(rowIndex);
Map<String, Object> rowDate = outPutParam.getContent().get(i);
//遍历列
for (int j = 0; j < outPutParam.getTitleList().size(); j++) {
Title headTitle = outPutParam.getTitleList().get(j);//获取第i行第j列列标题
String headerName = headTitle.getName();//获取第j列列标识
Object data = rowDate.get(headerName);//获取第i行第j列所放数据
HSSFCellStyle contextstyle =workbook.createCellStyle();
HSSFCell contentCell = contentRow.createCell(j);
Boolean isNum = false;//data是否为数值型
Boolean isInteger=false;//data是否为整数
Boolean isPercent=false;//data是否为百分数
if (data != null || "".equals(data)) {
//判断data是否为数值型
isNum = data.toString().matches("^(-?\\d+)(\\.\\d+)?$");
//判断data是否为整数(小数部分是否为0)
isInteger=data.toString().matches("^[-\\+]?[\\d]*$");
//判断data是否为百分数(是否包含“%”)
isPercent=data.toString().contains("%");
}

//如果单元格内容是数值类型,涉及到金钱(金额、本、利),则设置cell的类型为数值型,设置data的类型为数值类型
if (isNum && !isPercent) {
HSSFDataFormat df = workbook.createDataFormat(); // 此处设置数据格式
if (isInteger) {
contextstyle.setDataFormat(df.getBuiltinFormat("#,#0"));//数据格式只显示整数
}else{
contextstyle.setDataFormat(df.getBuiltinFormat("#,##0.00"));//保留两位小数点
}
// 设置单元格格式
contentCell.setCellStyle(contextstyle);
// 设置单元格内容为double类型
contentCell.setCellValue(Double.parseDouble(data.toString()));
} else {
contentCell.setCellStyle(contextstyle);
// 设置单元格内容为字符型
contentCell.setCellValue(data.toString());
}
}
}
}123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051

  如上,有两个比较重要的点:
  1、先用正则表达式判断数据是否为数值型,如果为数值型,则设置单元格格式为整数或者小数;
  2、然后往单元格中存放数据的时候要设置数据的格式为double类型,如果查看poi的源码HSSFCell.java会发现设置数据的方法如下,所以用setCellValue(double)方法即可。
   

优化
  到了这里,您可能以为万事大吉啊了,其实上面的代码有个陷阱,如果不经过大数据量的测试是发觉不出来的哦~~
  如果数据量大的话,系统可能会报错“The maximum number of cell styles was exceeded. You can define up to 4000 styles in a .xls workbook”,原因是style创建的次数太多了,解决这个问题的方法很简单,在循环体外面创建单元格格式contextstyle(即把它当成一个“全局”变量),不要在循环内部创建。
  正确的代码如下:
/**
* 导出Excel-胡玉洋-2015年11月11日
*
*@param outPutParam Excel数据实体,包括要导出的excel标头、列标题、数据等
* */
private void createContentRows(ExcelParam outPutParam) {
HSSFWorkbook workbook=new HSSFWorkbook(); //创建一个Excel文件
HSSFCellStyle contextstyle =workbook.createCellStyle();
// 遍历集合数据,产生数据行
for (int i = 0; i < outPutParam.getContent().size(); i++) {
int rowIndex = i + 2;
HSSFRow contentRow = sheet.createRow(rowIndex);
Map<String, Object> rowDate = outPutParam.getContent().get(i);
//遍历列
for (int j = 0; j < outPutParam.getTitleList().size(); j++) {
Title headTitle = outPutParam.getTitleList().get(j);//获取第i行第j列列标题
String headerName = headTitle.getName();//获取第j列列标识
Object data = rowDate.get(headerName);//获取第i行第j列所放数据
HSSFCell contentCell = contentRow.createCell(j);
Boolean isNum = false;//data是否为数值型
Boolean isInteger=false;//data是否为整数
Boolean isPercent=false;//data是否为百分数
if (data != null || "".equals(data)) {
//判断data是否为数值型
isNum = data.toString().matches("^(-?\\d+)(\\.\\d+)?$");
//判断data是否为整数(小数部分是否为0)
isInteger=data.toString().matches("^[-\\+]?[\\d]*$");
//判断data是否为百分数(是否包含“%”)
isPercent=data.toString().contains("%");
}

//如果单元格内容是数值类型,涉及到金钱(金额、本、利),则设置cell的类型为数值型,设置data的类型为数值类型
if (isNum && !isPercent) {
HSSFDataFormat df = workbook.createDataFormat(); // 此处设置数据格式
if (isInteger) {
contextstyle.setDataFormat(df.getBuiltinFormat("#,#0"));//数据格式只显示整数
}else{
contextstyle.setDataFormat(df.getBuiltinFormat("#,##0.00"));//保留两位小数点
}
// 设置单元格格式
contentCell.setCellStyle(contextstyle);
// 设置单元格内容为double类型
contentCell.setCellValue(Double.parseDouble(data.toString()));
} else {
contentCell.setCellStyle(contextstyle);
// 设置单元格内容为字符型
contentCell.setCellValue(data.toString());
}
}
}
}123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
社保到期了还有时效吗 2023年河北退休人员认证时间 社保待遇资格认证有效期怎么认证 ...语法How long does it take you to get to school? 此句中“it... 海信电视初始设置后无信号 设置海信电视恢复出厂设置搜不到电视信号 海信一族电视大锅恢复设置没信号怎么? 如何用c程序读取txt文件? 成都膨胀螺丝型号 云南农信个人如何开通手机银行 苹果四件套是什么? 苹果三件套是指哪三件?上大学不买这个会在同学面前很没面子? java中的类超级无敌多,我是一个新手,现在学起来觉得很吃力,我要怎样学习java中的API类库才更有效率? QQ账号申述 没3个好友帮忙辅助会降成功率吗 QQ账号无好友 有3年Q龄这种情况通过申诉的几率有多大? 不在常用IP申诉QQ,成功几率大吗,在没有好友辅助的情况下,高手来,不要废话 QQ申诉成功的几率有多高? qq申述只有一个好友帮忙成功率多高? QQ帐号申诉中没有详细资料,没有好友辅助,没有以前用过的密码,申述成功的几率有多少? 我申诉qq 只有好友是才加的几天成功率是多少 QQ申诉没有好友辅助会成功么 请问QQ申诉如果没有好友能成功吗 129运动的小故事 129爱国运动演讲稿 要最新出炉的 跪求...........................!!!!!! 申诉qq没好友成功的几率是多少 129运动征文200字 129运动意义 我们应该怎么做 关于129运动的资料 关于129运动的名言 50字129运动历史内容 用POI生成Excel表时,怎么设置单元格居左,居右 poi 导出excel 怎么设置合并的单元格自动换行 poi 如何实现中单元格的垂直居中对齐且水平居中对齐 java怎么用poi设置excel单元格边框??? poi设置excel单元格必须填写邮箱? poi设置的单元格格式是全局的吗 poi excel导出 单元格斜线实现??? 苹果三件套包含什么 低,中,高纬的分界线 世界南北纬度的分界线是什么 中高纬度分界线 南北纬度的分界线 地球三大纬度带中,低纬度与中纬度的分界线是?中纬度与高纬度的分界线是 中高纬度的分界线 高、中、低纬度的分界线分别是——? 南北半球纬度分界线是多少? 高低中纬度的界线是什么 经纬度划分以什么经线为界 地理:中纬度和低纬度。中纬度和高纬度的分界线 东西半球,南北半球,分界线和经度纬度分界线分别是?