有关java通过poi处理excle中合并单元格的问题

java 通过poi读取当前excle 将一级二级三级编号组合(如第一行组合后应为10010101、第二行为10010102),将组合后的数值复制到全新的excle中第一行第一列中 以此类推本人初学者 麻烦大师们能提供可用的代码 个人觉得难点就在第一个单元格为合并单元格不知道怎么与二、三级菜单对应。

难点是:第一个单元格为合并单元格,不知道怎么与第二,第三级菜单对应
方案一:将合并的单元格还原
步骤:
1.获取合并区域,将合并区域还原,并且还原后的值为之前合并区域值内容。
2.重新按照行读取即可以。

创建数组做映射,无需生成文件

private void decodeMergeCell(HSSFSheet templateSheet) {
int numMerge = templateSheet.getNumMergedRegions();
CellRangeAddress region = null;

while(numMerge >0){
region = templateSheet.getMergedRegion(0);

if (region.getFirstColumn() == 0 || region.getFirstColumn() == 1) {

HSSFRow row = templateSheet.getRow(region.getFirstRow());
HSSFCell cell = row.getCell(region.getFirstColumn());
String value = cell.getStringCellValue();
templateSheet.removeMergedRegion(0);

for (int j = region.getFirstRow(); j <=region.getLastRow(); j++) {

cell = templateSheet.getRow(j).getCell(
region.getFirstColumn());
cell.setCellValue(value);
}
}
numMerge = templateSheet.getNumMergedRegions();
}
温馨提示:答案为网友推荐,仅供参考
第1个回答  2013-09-05
HSSFSheet.getNumMergedRegions取合并格个数,HSSFSheet.getMergedRegionAt取第几个合并格的合并区域
循环几下就可取到当前格的合并行数本回答被网友采纳
相似回答