POI HSS 合并重复的列
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.HashMap;
import java.util.List;
import java.util.Map; import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFFont;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.hssf.util.Region;
import org.apache.poi.ss.usermodel.Font;
import org.apache.poi.ss.util.CellRangeAddress;
import org.hibernate.SQLQuery;
import org.hibernate.transform.Transformers;
import org.jboss.seam.annotations.Name;
import org.jboss.seam.annotations.remoting.WebRemote; import com.sunsheen.jfids.system.base.composite.data.query.QueryParameterImpl;
import com.sunsheen.jfids.system.database.DBSession;
import com.sunsheen.jfids.util.DataBaseUtil; public class SalaryPoi { @SuppressWarnings("deprecation")
public String getToExcel(){
......省略数据源获取
// 返回表单结果集
List list = query.list();
int size = list.size();
System.out.println("+++++++++++++" + size); //初始化POI
//创建工作簿---->XSSF代表10版的Excel(HSSF是07版前的Excel)
HSSFWorkbook wb = new HSSFWorkbook(); //工作表
HSSFSheet sheet = wb.createSheet("淞幸科技"); //标头行,代表第一行
HSSFRow head=sheet.createRow(0);
HSSFCell hssfCell=head.createCell(0); hssfCell.setCellValue("成都淞幸科技有限责任公司"+date.substring(0,4)+"年"+
date.substring(date.length()-2,date.length())+"月工资表");
head.setHeightInPoints(70); //合并第一行的单元格
CellRangeAddress address=new CellRangeAddress(0,0,0,26);
sheet.addMergedRegion(address); //创建字体与风格
HSSFCellStyle cellStyle = wb.createCellStyle();//生成表头格样式
HSSFFont hssfFont = wb.createFont();//创建字体
hssfFont.setFontHeightInPoints((short)12);//字体大小
hssfFont.setBoldweight(Font.BOLDWEIGHT_BOLD);//粗体
cellStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);//水平居中
cellStyle.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);//垂直居中
cellStyle.setFont(hssfFont);
hssfCell.setCellStyle(cellStyle); //修饰风格2
HSSFCellStyle cellStyle2 = wb.createCellStyle();//生成表头格样式
cellStyle2.setAlignment(HSSFCellStyle.ALIGN_CENTER);//水平居中
cellStyle2.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);//垂直居中 HSSFRow header=sheet.createRow(1);
//创建单元格,0代表第一行第一列
String[] heards ={"序号","部门名称","工号","姓名","银行卡号","定级工资","岗位工资","基础
,"实发工资总额"......};
for(int i =0;i<heards.length;i++){
HSSFCell hssfCell1=header.createCell(i);
hssfCell1.setCellStyle(cellStyle2);
hssfCell1.setCellValue(heards[i]);
}
//设置列的宽度
// getPhysicalNumberOfCells()代表这行有多少包含数据的列
for(int i=0;i<header.getPhysicalNumberOfCells();i++){
//POI设置列宽度时比较特殊,它的基本单位是1/255个字符大小,
//因此我们要想让列能够盛的下20个字符的话,就需要用255*20
sheet.setColumnWidth(i, 255*15);
}
//设置行高,行高的单位就是像素,因此30就是30像素的意思
header.setHeightInPoints(30);
int k =2;
//
for(int i=0;i<size;i++){
// //创建多行数据
HSSFRow headers=sheet.createRow(k++);
// //拿出所有查询出的一条list(list(Map<>))信息
Map<String, Object> map = (Map<String, Object>) list.get(i);
System.out.println(map); String[] context ={你要写入的数据};
for(int j=0;j<context.length;j++){
HSSFCell hssfCell2=headers.createCell(j);
hssfCell2.setCellStyle(cellStyle2);
hssfCell2.setCellValue(context[j]);
}
} // 合并相同列中的数据
// 处理相同的数据合并单元格
if(sheet.getLastRowNum()>2){//获取最后一行行标,比行数小 满足合并的条件,2是数据行的开始,0 1 行为表头
HSSFRow row_1 = sheet.getRow(2);
HSSFCell cell_1 = row_1.getCell(1); String departname = cell_1.getStringCellValue(); for(int i=3;i<=sheet.getLastRowNum();i++){
//除第一个外,循环将内容相同的单元格设为"",这里体现出为什么原数据要有序!
HSSFRow rows = sheet.getRow(i);
//此处表示对单元格进行内容相同合并处理,我这里获取的是每行的第2列进行对比,要多列对比的,这里自行增加
HSSFCell cells_1 = rows.getCell(1);
//这里值相同则设置位空,方便之后的合并
if(departname.equals(cells_1.getStringCellValue())){
cells_1.setCellValue("");
}else{
departname = cells_1.getStringCellValue();
}
}
}
int sk;
if(sheet.getLastRowNum()>2){//将为空的单元格与之前不为空的合并
sk=2;
for(int i=3;i<=sheet.getLastRowNum();i++){
HSSFRow rows = sheet.getRow(i);
HSSFCell cell_0 = rows.getCell(1);
if(cell_0.getStringCellValue() == ""){//如果为空但还没对比到最后一行,继续循环
if(i==sheet.getLastRowNum()){
sheet.addMergedRegion(new CellRangeAddress(sk, i, 1, 1));//如果已经对比到最后一行,开始合并
}
}else{
if(sk != i-1){//不为空且i-1不为sk则合并
sheet.addMergedRegion(new CellRangeAddress(sk, i-1, 1, 1));//起始行号,终止行号, 起始列号,终止列号
}
sk =i;
}
}
}
//上面设置好了内容,我们当然是要输出到某个文件的,输出就需要有输出流
FileOutputStream fos;
try {
fos = new FileOutputStream("d:/2010.xls");
//向指定文件写入内容
wb.write(fos);
fos.close();
return "导出Excel已完成!"; } catch (FileNotFoundException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (IOException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} return "导出Excel失败!";
}
}
POI HSS 合并重复的列的更多相关文章
- ASP.NET中重复表格列合并的实现方法(转自脚本之家)
这几天做一个项目有用到表格显示数据的地方,客户要求重复的数据列需要合并,就总结了一下.NET控件GridView 和 Repeater 关于重复数据合并的方法. 这是合并之前的效果: 合并之后的效果图 ...
- POI Excel 合并数据相同的行
import java.io.Serializable; /** * POI Excel报表导出,列合并实体<br> * * @author WQ * */ public class Po ...
- poi读取合并单元格
poi读取合并单元格 学习了:http://blog.csdn.net/ycb1689/article/details/9764191 进行了列合并单元格的修正:原来是我自己找错了地方: import ...
- POI 怎么设置Excel整列的CellStyle啊
POI 怎么设置Excel整列的CellStyle啊,而不是循环每个Cell.因为现在是生成Excel模板,不知道客户会输入多少行. 问题补充: 指尖言 写道 好像没有这个方法,CellStyle是C ...
- poi获取合并单元格内的第一行第一列的值
当读取如图所示的excel时,显示为第1行 第1列 的内容是:合并单元格 其它在合并单元格区域内的单元格不显示 示例代码如下: import java.io.FileInputStream; impo ...
- Java导出Excel表,POI 实现合并单元格以及列自适应宽度(转载)
POI是apache提供的一个读写Excel文档的开源组件,在操作excel时常要合并单元格,合并单元格的方法是: sheet.addMergedRegion(new CellRangeAddress ...
- POI 实现合并单元格以及列自适应宽度
POI是apache提供的一个读写Excel文档的开源组件,在操作excel时常要合并单元格,合并单元格的方法是: sheet.addMergedRegion(new CellRangeAddress ...
- POI 简单合并单元格
public class MergedCells { /** 测试使用的POI版本是3.1 * @param args */ public static void main(String[] args ...
- poi excel 合并单元格
结论:final CellRangeAddress cra = new CellRangeAddress(rowId, rowId + rowSkip, colId, colId + c ...
随机推荐
- sqlite迁移mysql(导入导出数据)
第一步,将数据导出 进入sqlite3->.open [打开文件路径]->.cd [要保存的路径]->.output [导出文件名字.sql]->.dump 等待导出成功后,就 ...
- 【Linux-CentOS】【转-更正】使用CentOS DVD1 和DVD2做本地yum源
原文在此.此文写的非常好,怕网络丢失,特转来,并做了更正. CentOS6以上版本一般都会提供一个DVD1和一个DVD2镜像,使用DVD1即可安装使用CentOS了,DVD2中存放了一些额外的软件包, ...
- deep learning学习记录二
接着我的微博继续八卦吧 微博里问了几个人,关于deep learning和cnn的区别,有不少热心网友给了回答,非常感谢.结合我听课和看文章的理解,我大胆大概总结一下: 在上世纪90年代,neural ...
- Java秒杀系统方案优化 高性能高并发实战(已完成)
1:商品列表 2:商品详情判断是否可以开始秒杀,未开始不显示秒杀按钮显示倒计时,开始显示秒杀按钮,同时会显示验证码输入框以及验证码图片,当点击秒杀按钮的时候会首先判断验证码是否正确,如果正确会返回一个 ...
- zTree的核心处理逻辑
zTree 是一个前端树形结构的插件. 使用起来很简单,我们重点关注一下插件的核心代码. 首先,zTree需要如下的数据结构: let areaData = [ { "id": & ...
- 『ACM C++』 PTA 天梯赛练习集L1 | 001-006
应师兄要求,在打三月底天梯赛之前要把PTA上面的练习集刷完,所以后面的时间就献给PTA啦~ 后面每天刷的题都会把答案代码贡献出来,如果有好的思路想法也会分享一下~ 欢迎大佬提供更好的高效率算法鸭~ - ...
- Java 的标识接口作用
原文地址:标识接口 作用作者:feisong 时间:2019-01-2315:49:35 标识接口是没有任何方法和属性的接口.标识接口不对实现它的类有任何语义上的要求,它仅仅表明实现它的类属于一个特定 ...
- 一次Redis 的性能测试和问题 [问题已经自己解决,见文章最后]
[我的问题]:请教个问题,我在本机搭建linux虚拟机+redis 3.2.6,然后在本机物理机上面测试虚拟机的redis性能,如下VM配置参数做测试,redis 的性能好像不算太好,问题待排查的两点 ...
- 官方yum源安装选择所需版本mysql数据库并初始化(yum默认安装的是最新版MySQL8.+)
在官网是找不到5.x系列的域名源的,系统默认是安装的oracle数据库,在安装前需要删除默认的 以下教程来源于官网说明 先去官网下载yum源,地址 https://dev.mysql.com/down ...
- Leecode刷题之旅-C语言/python-88合并两个有序数组
/* * @lc app=leetcode.cn id=88 lang=c * * [88] 合并两个有序数组 * * https://leetcode-cn.com/problems/merge-s ...