excel表格打印每页都有表头_怎样设置Word表格打印时每页都显示表头?不会的看看这篇教程!...

用Word打印一份长表格时,第一页通常有表头,第二页开始就没有,我们不想每次打印的时候都去编辑输入,希望可以一次设置所有表格都有表头。有什么方法可以解决呢?

a50b1124ff5540157d665fcc537c58bd.png

具体操作步骤如下:

1、打开要设置表头的Word文档 -- 选择表格中表头的内容 -- 点击“鼠标右键”-- 选择“表格属性”。

38291445f0caacdcab8e72d838046a50.png

2、弹出“表格属性”对话框 -- 切换到“行”选项卡 -- 在“选项”栏下方的“在各页顶端以标题行形式重复出现”前面的复选框打钩-- 点击“确定”按钮。

07f219e7c323173178193d8113343223.png

3、设置完成之后可以看到每一页的表格自动生成表头了。

616ae0f7facedc1745f0dcf13e130785.png

4、完整的动图演示。

70d62240d70586736a8ddef4a724eef6.gif

以上的方法您学会了吗?有问题可在评论区留言哦~期待您的关注、转发与点赞!

您的关注、转发、评论、点赞、收藏都是对小编的鼓励与支持,谢谢您!

以下是Java Web中打印Excel每页都带表头的示例代码: ```java import java.io.FileInputStream; import java.io.IOException; import java.io.InputStream; import java.util.List; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.poi.hssf.usermodel.HSSFCellStyle; import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.apache.poi.ss.usermodel.CellStyle; import org.apache.poi.ss.usermodel.HeaderFooter; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet; import org.apache.poi.ss.usermodel.Workbook; import org.apache.poi.xssf.usermodel.XSSFWorkbook; @WebServlet("/printExcel") public class PrintExcelServlet extends HttpServlet { private static final long serialVersionUID = 1L; protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String filePath = request.getParameter("filePath"); String fileType = filePath.substring(filePath.lastIndexOf(".") + 1); InputStream is = new FileInputStream(filePath); Workbook wb = null; if (fileType.equals("xls")) { wb = new HSSFWorkbook(is); } else if (fileType.equals("xlsx")) { wb = new XSSFWorkbook(is); } Sheet sheet = wb.getSheetAt(0); response.setContentType("application/vnd.ms-excel"); response.setHeader("Content-Disposition", "attachment;filename=printExcel.xlsx"); int lastRowNum = sheet.getLastRowNum(); int pageSize = 20; // 每页显示的行数 int totalPage = (lastRowNum + 1) % pageSize == 0 ? (lastRowNum + 1) / pageSize : (lastRowNum + 1) / pageSize + 1; // 设置表头样式 CellStyle headerStyle = wb.createCellStyle(); headerStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER); headerStyle.setBorderBottom(HSSFCellStyle.BORDER_THIN); headerStyle.setBorderLeft(HSSFCellStyle.BORDER_THIN); headerStyle.setBorderRight(HSSFCellStyle.BORDER_THIN); headerStyle.setBorderTop(HSSFCellStyle.BORDER_THIN); // 设置页脚 HeaderFooter footer = sheet.getFooter(); footer.setRight("Page " + HeaderFooter.page() + " of " + HeaderFooter.numPages()); for (int i = 0; i < totalPage; i++) { int startRow = i * pageSize; int endRow = (i + 1) * pageSize - 1; if (endRow > lastRowNum) { endRow = lastRowNum; } // 设置每页表头 Row row = sheet.getRow(0); Row headerRow = sheet.createRow(startRow); headerRow.setHeight(row.getHeight()); List<Cell> headerCells = row.getCells(); for (int j = 0; j < headerCells.size(); j++) { Cell cell = headerRow.createCell(j); cell.setCellValue(headerCells.get(j).getStringCellValue()); cell.setCellStyle(headerStyle); } // 设置每页的数据 for (int j = startRow + 1; j <= endRow; j++) { row = sheet.getRow(j); Row dataRow = sheet.createRow(j + 1); dataRow.setHeight(row.getHeight()); List<Cell> dataCells = row.getCells(); for (int k = 0; k < dataCells.size(); k++) { Cell cell = dataRow.createCell(k); cell.setCellValue(dataCells.get(k).getStringCellValue()); } } } wb.write(response.getOutputStream()); wb.close(); is.close(); } protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doGet(request, response); } } ``` 在上述代码中,我们首先获取Excel文件的输入流,并通过文件类型判断创建Workbook对象。然后,设置响应的Content-Type和Content-Disposition头,以便浏览器可以正确下载Excel文件。 接下来,我们根据每页显示的行数和总行数计算出总页数,并通过循环遍历每一页来设置表头和数据。在设置表头,我们首先获取第一行的所有单元格,并创建一个新的行来设置表头样式和内容。在设置数据,我们遍历每行的单元格,并将其内容复制到新创建的行中。 最后,我们通过Workbook对象的write方法将Excel文件的内容写入到响应的输出流中,然后关闭输入流和Workbook对象。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值