永发信息网

java excel 怎么合并大的单元格

答案:2  悬赏:50  手机版
解决时间 2021-03-12 05:19
java excel 怎么合并大的单元格
最佳答案
POIexcel表格何合并单元格

Java代码
import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
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;

public class ExcelTest {


public static void main(String[] args) throws IOException {

try {
HSSFWorkbook wb = new HSSFWorkbook();
HSSFSheet sheet = wb.createSheet("new sheet");
HSSFCellStyle style = wb.createCellStyle(); // 式象

style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);// 垂直
style.setAlignment(HSSFCellStyle.ALIGN_CENTER);// 水平
HSSFRow row = sheet.createRow((short) 0);
HSSFRow row2 = sheet.createRow((short) 1);

sheet.addMergedRegion(new Region(0, (short) 0, 1, (short) 0));
HSSFCell ce = row.createCell((short) 0);
ce.setEncoding(HSSFCell.ENCODING_UTF_16);// 文处理
ce.setCellValue("项目\\期"); // 表格第行第列显示数据
ce.setCellStyle(style); // 式居
int num = 0;
for (int i = 0; i < 9; i++) { // 循环9每都要跨单元格显示
// 计算单元格跨格
int celln = 0;
int celle = 0;
if (i == 0) {
celln = 0;
celle = 1;
} else {
celln = (i * 2);
celle = (i * 2 + 1);
}
// 单元格合并
// 四参数别:起始行起始列结束行结束列
sheet.addMergedRegion(new Region(0, (short) (celln + 1), 0,
(short) (celle + 1)));
HSSFCell cell = row.createCell((short) (celln + 1));
cell.setCellValue("merging" + i); // 跨单元格显示数据
cell.setCellStyle(style); // 式
// 跨单元格显示数据:两行行别两格格行两格数量金额
HSSFCell cell1 = row2.createCell((short) celle);
HSSFCell cell2 = row2.createCell((short) (celle + 1));
cell1.setEncoding(HSSFCell.ENCODING_UTF_16);
cell1.setCellValue("数量");
cell1.setCellStyle(style);
cell2.setEncoding(HSSFCell.ENCODING_UTF_16);
cell2.setCellValue("金额");
cell2.setCellStyle(style);
num++;
}

// 面加合计百比

// 合计 加要跨单元格
sheet.addMergedRegion(new Region(0, (short) (2 * num + 1), 0,
(short) (2 * num + 2)));
HSSFCell cell = row.createCell((short) (2 * num + 1));
cell.setEncoding(HSSFCell.ENCODING_UTF_16);
cell.setCellValue("合计");
cell.setCellStyle(style);
HSSFCell cell1 = row2.createCell((short) (2 * num + 1));
HSSFCell cell2 = row2.createCell((short) (2 * num + 2));
cell1.setEncoding(HSSFCell.ENCODING_UTF_16);
cell1.setCellValue("数量");
cell1.setCellStyle(style);
cell2.setEncoding(HSSFCell.ENCODING_UTF_16);
cell2.setCellValue("金额");
cell2.setCellStyle(style);

// 百比 同
sheet.addMergedRegion(new Region(0, (short) (2 * num + 3), 0,
(short) (2 * num + 4)));
HSSFCell cellb = row.createCell((short) (2 * num + 3));
cellb.setEncoding(HSSFCell.ENCODING_UTF_16);
cellb.setCellValue("百比");
cellb.setCellStyle(style);
HSSFCell cellb1 = row2.createCell((short) (2 * num + 3));
HSSFCell cellb2 = row2.createCell((short) (2 * num + 4));
cellb1.setEncoding(HSSFCell.ENCODING_UTF_16);
cellb1.setCellValue("数量");
cellb1.setCellStyle(style);
cellb2.setEncoding(HSSFCell.ENCODING_UTF_16);
cellb2.setCellValue("金额");
cellb2.setCellStyle(style);

FileOutputStream fileOut = new FileOutputStream("workbook.xls");
wb.write(fileOut);
fileOut.close();
System.out.print("OK");
} catch (Exception ex) {
ex.printStackTrace();
}

}

}
全部回答
我有个思路: 使用offset函数,取第一个单元格之后的值,与第一个单元格中的值相比较,如果相同,就继续下一个offset取值、判断,如果不同就记录下这个单元格的行做为合并的终止行,进行合并。从这个单元格的下一个单元格继续开始循环判断。
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
便宜的几十块钱的狗狗,就一定比一千多块钱的
海洋石油平台和导管架平台区别
阿玉羊绒这个地址在什么地方,我要处理点事
如图为某山区等高线地形图,按要求完成问题。
蓝山咖啡和雀巢咖啡哪个好啊?
静颜堂中式美容养生在什么地方啊,我要过去处
PP塑料抽粒后还可达食品级吗?
肥仔螺蛳粉地址有知道的么?有点事想过去
iphone邮箱主机名
张浦不锈钢地址在哪,我要去那里办事
凉水和白酒两混能喝吗?能醒酒吗?
马坊西路我想知道这个在什么地方
新郎新娘入洞房打一字(是一朋友让我猜的,我
我的文曲星A1000+密码忘了,有什么办法破掉它
按照风险发生后对项目的影响大小,可以划分为
推荐资讯
广州东站到广州白云区三元里大道1231号怎么坐
有人说压力就是动力,压力越大,动力就越大,所
工程质量监督站对私人装修工程进行质量验收吗
种植中药材哪些药材前景好
我的魔域仓库密码忘了怎么办啦
如何从goodygis上导出地形
成为中级会计师的基本条件是什么?
白色椰子怎么打开图解
谁知道五菱荣光,五菱宏光裸车的具体价格,请
笡命八字出生,1981年农历10月,18日名字怎么
男土蛇,女木猪命配吗?
从房山到涿州的22路早班车几点啊,一定要准确
正方形一边上任一点到这个正方形两条对角线的
阴历怎么看 ?