package com.paic.pacz.core.salesmanage.util;

import java.util.List;

import org.apache.commons.beanutils.PropertyUtils;
import org.apache.poi.xssf.usermodel.XSSFCell;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.springframework.util.CollectionUtils; import com.paic.icore.fa.logging.Log;
import com.paic.pacz.core.salesmanage.dto.ExportExcelDTO;
import com.paic.pacz.core.salesmanage.dto.ExportExcelPropertyDTO; public class ExportExcelUtil{
/** 日志服务 */
private Log log; /**
* 创建sheet
* @param xssfWorkbook 工作簿
* @return
*/
private XSSFSheet createSheet(XSSFWorkbook xssfWorkbook){
XSSFSheet sheet=xssfWorkbook.createSheet();
log.trace("XSSFSheet 创建成功");
return sheet;
} /**
* 设置表头值
* @param sheet
* @param haeders
* @throws Exception
*/
private void setHaeder(XSSFSheet sheet,List<String> haeders){
// 第三步,在sheet中添加表头第0行,注意老版本poi对Excel的行数列数有限制short
XSSFRow haederRow = sheet.createRow();
for(int i=;i<haeders.size();i++){
//创建表头的cell
XSSFCell xssfCell=haederRow.createCell(i);
//给表头的cell赋值
xssfCell.setCellValue(haeders.get(i));
}
log.trace("Excel 表头信息设置成功");
}
/**
* 给Excel添加数据
* @param datas 数据对象集合
* @param sheet
* @param cellSize 每row的cell数
* @throws Exception
*/
private void setExeclCellValue(List<ExportExcelPropertyDTO> datas,XSSFSheet sheet,Integer cellSize)throws Exception{
//没有数据时终止生成数据
if(CollectionUtils.isEmpty(datas))return;
int rowIndex=;//数据行从第1行开始,第0行为表头
//循环给 每row的每cell赋值
for(ExportExcelPropertyDTO exportExcelPropertyDTO:datas){
XSSFRow dataRow=sheet.createRow(rowIndex);
setCellVal(exportExcelPropertyDTO, dataRow, cellSize);
rowIndex++;
}
//赋值完成 清空数据对象集合
datas.clear();
log.trace("Excel 数据添加成功");
} /**
* 设置cell的值
* @param excelDTO 数据对象
* @param dataRow excel的行
* @param cellSize 每行的cell的数量
* @throws Exception
*/
private void setCellVal(ExportExcelPropertyDTO exportExcelPropertyDTO,XSSFRow dataRow,Integer cellSize)throws Exception{
for(int i=;i<cellSize;i++){
//创建 cell
XSSFCell cell=dataRow.createCell(i);
//生成数据对象的属性(property)
String property="porp"+i;
//获取数据对象中对应属性(property)的值
Object val=null;
try{
val=PropertyUtils.getProperty(exportExcelPropertyDTO, property);
}catch(Exception e){
log.error("获取属性::"+property+" 的值出错!Message:::"+e.getMessage(), e);
}
if(!CommonUtil.isNull(val)){//值不为空时,赋值
if(val instanceof Double){
cell.setCellValue(Double.parseDouble(val.toString()));//统一转成String的数据
}else{
cell.setCellValue(val.toString());//统一转成String的数据
} }else{//值为空时,赋值""
cell.setCellValue("");
}
}
log.trace("每行设置值成功");
} /**
* 导出Excel文件
* @param httpServletResponse
* @param exportExcelDTO
* @throws Exception
*/
public void exportExcel(XSSFWorkbook workbook,ExportExcelDTO exportExcelDTO) throws Exception{
//表头信息为空是终止导出数据
if(CollectionUtils.isEmpty(exportExcelDTO.getHeaders()))return;
//创建sheet
XSSFSheet sheet=createSheet(workbook);
//设置表头信息
setHaeder(sheet, exportExcelDTO.getHeaders());
//获取每一行row的cell的数量
Integer cellSize=exportExcelDTO.getHeaders().size();
//给row的cell赋值
setExeclCellValue(exportExcelDTO.getExcelPropertyDTOs(), sheet,cellSize);
} public Log getLog() {
return log;
}
public void setLog(Log log) {
this.log = log;
} }

工具类Util类的注释书写规范的更多相关文章

  1. C# T4 模板 数据库实体类生成模板(带注释,娱乐用)

     说明:..,有些工具生成实体类没注释,不能和SqlServer的MS_Description属性一起使用,然后照着网上的资源,随便写了个生成模板,自娱自乐向,其实卵用都没有参考教程    1.htt ...

  2. property_自己编写一个读取Property文件的Util类

    读取property文件的Util类: 所需jar包: 编写PropertiesUtil类: package com.west.util.property; import java.io.InputS ...

  3. JAVASE学习笔记:第八章 经常使用类Util工具包之日期类、数字类

    一.Date类   日期类 所在java.Util工具包     before(Date when)   測试此日期是否在指定日期之前. getDay()  获取星期的某一天     getDate( ...

  4. 开发工具、Object类(java基础知识十一)

    1.常见开发工具介绍 * A:操作系统自带的记事本软件 * B:高级记事本软件 * C:集成开发环境 IDE     * (Integrated Development Environment) *  ...

  5. 使用工厂方法模式设计能够实现包含加法(+)、减法(-)、乘法(*)、除法(/)四种运算的计算机程序,要求输入两个数和运算符,得到运算结果。要求使用相关的工具绘制UML类图并严格按照类图的设计编写程序实

    2.使用工厂方法模式设计能够实现包含加法(+).减法(-).乘法(*).除法(/)四种运算的计算机程序,要求输入两个数和运算符,得到运算结果.要求使用相关的工具绘制UML类图并严格按照类图的设计编写程 ...

  6. 1、使用简单工厂模式设计能够实现包含加法(+)、减法(-)、乘法(*)、除法(/)四种运算的计算机程序,要求输入两个数和运算符,得到运算结果。要求使用相关的工具绘制UML类图并严格按照类图的设计编写程

    1.使用简单工厂模式设计能够实现包含加法(+).减法(-).乘法(*).除法(/)四种运算的计算机程序,要求输入两个数和运算符,得到运算结果.要求使用相关的工具绘制UML类图并严格按照类图的设计编写程 ...

  7. [C#] 常用工具类——系统日志类

    using System; using System.Collections.Generic; using System.Text; using System.Diagnostics; namespa ...

  8. idea live template高级知识, 进阶(给方法,类,js方法添加注释)

    为了解决用一个命令(宏)给方法,类,js方法添加注释,经过几天的研究.终于得到结果了. 实现的效果如下: 给Java中的method添加方法: /** * * @Method : addMenu * ...

  9. MyBatis别名与util类技能了解

    1.别名 在java中String类型就是String类型,但是在MyBatis中可不会识别java中的类型,在MyBatis中String类型的别名是'string',小写的String,或者也可以 ...

随机推荐

  1. luogu1967 货车运输 最大瓶颈生成树

    题目大意 给出一张图,给出q对点,求这两个点间权值最小边最大的路径,输出这个最小边权. 题解 我们先一条一条边建图.当建立的边使得图中形成环时,因为环中的每个节点只考虑是否连通和瓶颈大小,要想互相连通 ...

  2. vim设置为indent折叠以后,每次打开文件时代码处于折叠状态,能改变吗?

    vim设置为indent折叠以后,每次打开文件时代码处于折叠状态.即使这次编辑的时候把折叠展开,保存关闭文件,重新打开,所有的代码都又折叠起来了. 请问有没有默认不折叠的方法? 是否有可以一次展开所有 ...

  3. 【NOIP 2004】 虫食算

    [题目链接] https://www.luogu.org/problemnew/show/P1092 [算法] 搜索 + 剪枝 直接搜索显然会超时,考虑剪枝 1 : 优化搜索顺序 2 : 假设我们已经 ...

  4. POJ 2492 A Bug's Life 带权并查集

    题意: 思路: mod2 意义下的带权并查集 如果两只虫子是异性恋,它们的距离应该是1. 如果两只虫子相恋且距离为零,则它们是同性恋. (出题人好猥琐啊) 注意: 不能输入一半就break出来.... ...

  5. 介绍一个简单的Parser

    我们已经学习了怎样创建一个简单的Monad, MaybeMonad, 并且知道了它如何通过在 Bind函数里封装处理空值的逻辑来移除样板式代码. 正如之前所说的,我们可以在Bind函数中封装更复杂的逻 ...

  6. [hihocoder][Offer收割]编程练习赛45

    互补二元组 Xi + Xj = Yi + Yj等价于Xi - Yi + Xj - Yj = 0 ,对每个二元组计算其x与y的差,每次加上其相反数的个数. #pragma comment(linker, ...

  7. javascript中构造函数的三种方式

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  8. mybatis学习笔记之基础复习(3)

    mybatis学习笔记之基础复习(3) mybatis是什么? mybatis是一个持久层框架,mybatis是一个不完全的ORM框架.sql语句需要程序员自己编写, 但是mybatis也是有映射(输 ...

  9. (转载)activity外部调用startActivity的new task异常解析

    activity外部调用startActivity的new task异常解析 泡在网上的日子 / 文 发表于2013-09-07 12:45  第1314次阅读 异常,android,activity ...

  10. dotnetnuke7.3.3 下弹出对话框(dnnConfirm())的使用

    今天用dnn做一个列表里边有一个删除操作,就想做个对话框确定是否删除? 正常理解马上想到js的confirm("")函数,但是发现Dnn把这个函数给重写啦,弹出的对话框竟然是英文的 ...