Java 在合并两个excel文件期间操作单元格
我试图在合并两个excel文件时在它们之间添加标题。这两个文件有表,我可以将它们合并在一起,但我不知道如何在这两个表之间添加标题。 我的代码中负责合并工作表的部分如下所示:Java 在合并两个excel文件期间操作单元格,java,excel,apache-poi,Java,Excel,Apache Poi,我试图在合并两个excel文件时在它们之间添加标题。这两个文件有表,我可以将它们合并在一起,但我不知道如何在这两个表之间添加标题。 我的代码中负责合并工作表的部分如下所示: public static void addSheet(org.apache.poi.ss.usermodel.Sheet mergedSheet, org.apache.poi.ss.usermodel.Sheet sheet,String title) { // map for cell styles
public static void addSheet(org.apache.poi.ss.usermodel.Sheet mergedSheet, org.apache.poi.ss.usermodel.Sheet sheet,String title) {
// map for cell styles
Map<Integer, org.apache.poi.ss.usermodel.CellStyle> styleMap = new HashMap<Integer, org.apache.poi.ss.usermodel.CellStyle>();
// This parameter is for appending sheet rows to mergedSheet in the end
int len = mergedSheet.getLastRowNum();
for (int j = sheet.getFirstRowNum(); j <= sheet.getLastRowNum(); j++) {
org.apache.poi.ss.usermodel.Row row = sheet.getRow(j);
org.apache.poi.ss.usermodel.Row mrow = mergedSheet.createRow(len + j + 1);
try {
for (int k = row.getFirstCellNum(); k < row.getLastCellNum(); k++) {
org.apache.poi.ss.usermodel.Cell cell=null;
if(row.getCell(k)!=null){
cell = row.getCell(k);
}else{
cell= row.createCell(k);
}
org.apache.poi.ss.usermodel.Cell mcell = mrow.createCell(k);
if (cell.getSheet().getWorkbook() == mcell.getSheet()
.getWorkbook()) {
mcell.setCellStyle(cell.getCellStyle());
} else {
int stHashCode = cell.getCellStyle().hashCode();
org.apache.poi.ss.usermodel.CellStyle newCellStyle = styleMap.get(stHashCode);
if (newCellStyle == null) {
newCellStyle = mcell.getSheet().getWorkbook()
.createCellStyle();
newCellStyle.cloneStyleFrom(cell.getCellStyle());
styleMap.put(stHashCode, newCellStyle);
}
mcell.setCellStyle(newCellStyle);
}
switch (cell.getCellType()) {
case HSSFCell.CELL_TYPE_FORMULA:
mcell.setCellFormula(cell.getCellFormula());
break;
case HSSFCell.CELL_TYPE_NUMERIC:
mcell.setCellValue(cell.getNumericCellValue());
break;
case HSSFCell.CELL_TYPE_STRING:
mcell.setCellValue(cell.getStringCellValue());
break;
case HSSFCell.CELL_TYPE_BLANK:
mcell.setCellType(HSSFCell.CELL_TYPE_BLANK);
break;
case HSSFCell.CELL_TYPE_BOOLEAN:
mcell.setCellValue(cell.getBooleanCellValue());
break;
case HSSFCell.CELL_TYPE_ERROR:
mcell.setCellErrorValue(cell.getErrorCellValue());
break;
default:
mcell.setCellValue(cell.getStringCellValue());
break;
}
}
} catch (Exception e) {
}
}
}
public static void addSheet(org.apache.poi.ss.usermodel.Sheet mergedSheet,org.apache.poi.ss.usermodel.Sheet,字符串标题){
//单元格样式的映射
Map styleMap=newhashmap();
//此参数用于在最后将图纸行追加到合并图纸
int len=mergedSheet.getLastRowNum();
对于(int j=sheet.getFirstRowNum();j可能不是您想要的,但是您可以创建第三个excel文件,其中只包含标题。啊,我明白了。您还可以在代码中创建电子表格,并将标题传递给它……或者在合并前将其添加到上一个/下一个电子表格的第一行/最后一行,而不保存。您有任何示例吗?这将非常好bly对Java有丰富的经验:addCaption(mergedsheet,0,LastY+1,title);但可能是这样的吗?