java 用poi 生成表格合并单元格放法

对于合并单元格的介绍不怎么多,下面是之前做word导出的时候研究的,在stackoverflow查到了点资料。

记录下两个关键方法:


http://blog.csdn.net/rudy1245/article/details/53421366


http://53873039oycg.iteye.com/blog/2152009

[java]  view plain  copy
  1. // word跨列合并单元格  
  2.     public  void mergeCellsHorizontal(XWPFTable table, int row, int fromCell, int toCell) {    
  3.         for (int cellIndex = fromCell; cellIndex <= toCell; cellIndex++) {    
  4.             XWPFTableCell cell = table.getRow(row).getCell(cellIndex);    
  5.             if ( cellIndex == fromCell ) {    
  6.                 // The first merged cell is set with RESTART merge value    
  7.                 cell.getCTTc().addNewTcPr().addNewHMerge().setVal(STMerge.RESTART);    
  8.             } else {    
  9.                 // Cells which join (merge) the first one, are set with CONTINUE    
  10.                 cell.getCTTc().addNewTcPr().addNewHMerge().setVal(STMerge.CONTINUE);    
  11.             }    
  12.         }    
  13.     }    
  14.     // word跨行并单元格  
  15.     public void mergeCellsVertically(XWPFTable table, int col, int fromRow, int toRow) {    
  16.         for (int rowIndex = fromRow; rowIndex <= toRow; rowIndex++) {    
  17.             XWPFTableCell cell = table.getRow(rowIndex).getCell(col);    
  18.             if ( rowIndex == fromRow ) {    
  19.                 // The first merged cell is set with RESTART merge value    
  20.                 cell.getCTTc().addNewTcPr().addNewVMerge().setVal(STMerge.RESTART);    
  21.             } else {    
  22.                 // Cells which join (merge) the first one, are set with CONTINUE    
  23.                 cell.getCTTc().addNewTcPr().addNewVMerge().setVal(STMerge.CONTINUE);    
  24.             }    
  25.         }    
  26.     }   

另外加上单元格字体设置的方法:

[html]  view plain  copy
  1. private void getParagraph(XWPFTableCell cell,String cellText){  
  2.         CTP ctp = CTP.Factory.newInstance();  
  3.         XWPFParagraph p = new XWPFParagraph(ctp, cell);  
  4.         p.setAlignment(ParagraphAlignment.CENTER);  
  5.         XWPFRun run = p.createRun();  
  6.         run.setText(cellText);  
  7.         CTRPr rpr = run.getCTR().isSetRPr() ? run.getCTR().getRPr() : run.getCTR().addNewRPr();  
  8.         CTFonts fonts = rpr.isSetRFonts() ? rpr.getRFonts() : rpr.addNewRFonts();  
  9.         fonts.setAscii("仿宋");  
  10.         fonts.setEastAsia("仿宋");  
  11.         fonts.setHAnsi("仿宋");  
  12.         cell.setParagraph(p);  
  13.     }  
下面是使用POI生成表格并自定义标题的Java示例代码: ```java import org.apache.poi.ss.usermodel.*; import org.apache.poi.xssf.usermodel.XSSFWorkbook; import java.io.FileOutputStream; import java.io.IOException; public class ExcelGenerator { public static void main(String[] args) throws IOException { // 创建工作簿 Workbook workbook = new XSSFWorkbook(); // 创建工作表 Sheet sheet = workbook.createSheet("表格名称"); // 创建自定义标题行 Row titleRow = sheet.createRow(0); CellStyle titleStyle = workbook.createCellStyle(); titleStyle.setAlignment(HorizontalAlignment.CENTER); Font titleFont = workbook.createFont(); titleFont.setBold(true); titleFont.setFontHeightInPoints((short) 14); titleStyle.setFont(titleFont); Cell titleCell = titleRow.createCell(0); titleCell.setCellValue("自定义标题"); titleCell.setCellStyle(titleStyle); sheet.addMergedRegion(new CellRangeAddress(0, 0, 0, 3)); // 创建表头行 Row headerRow = sheet.createRow(1); String[] headers = {"列1", "列2", "列3", "列4"}; CellStyle headerStyle = workbook.createCellStyle(); headerStyle.setAlignment(HorizontalAlignment.CENTER); Font headerFont = workbook.createFont(); headerFont.setBold(true); headerStyle.setFont(headerFont); for (int i = 0; i < headers.length; i++) { Cell headerCell = headerRow.createCell(i); headerCell.setCellValue(headers[i]); headerCell.setCellStyle(headerStyle); } // 创建数据行 Object[][] data = { {"数据1-1", "数据1-2", "数据1-3", "数据1-4"}, {"数据2-1", "数据2-2", "数据2-3", "数据2-4"}, {"数据3-1", "数据3-2", "数据3-3", "数据3-4"} }; CellStyle dataStyle = workbook.createCellStyle(); dataStyle.setAlignment(HorizontalAlignment.CENTER); for (int i = 0; i < data.length; i++) { Row dataRow = sheet.createRow(i + 2); for (int j = 0; j < data[i].length; j++) { Cell dataCell = dataRow.createCell(j); dataCell.setCellValue(data[i][j].toString()); dataCell.setCellStyle(dataStyle); } } // 调整列宽 for (int i = 0; i < headers.length; i++) { sheet.autoSizeColumn(i); } // 输出到文件 FileOutputStream outputStream = new FileOutputStream("表格文件名.xlsx"); workbook.write(outputStream); workbook.close(); outputStream.close(); } } ``` 在上面的示例中,我们通过以下步骤生成了一个包含自定义标题和表头的表格: 1. 创建工作簿。 2. 创建工作表。 3. 创建自定义标题行,并设置样式和字体。 4. 合并自定义标题单元格。 5. 创建表头行,并设置样式和字体。 6. 创建数据行,并设置样式。 7. 调整列宽。 8. 输出到文件。 你可以根据需要修改代码中的表格名称、自定义标题、表头、数据和输出文件名。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值