Excel2013打印时怎么固定表头及表尾让打印后的每页都可以看得到

在打印表格的过程中,想必大家会遇到这样的问题,就是当表格特别大时,而且只有首页有表头,其他页都没有,这样就算打印出来也不利于查看,因为并不是每一页都有表头。有什么方法可以将表头固定起来,在打印之后每页都可以看到?这种结果是我们每个人的初愿吧!如果还有朋友不知道什么是表头、什么是表尾的话,那么可以看看下面的介绍。在Excel2013中通过“顶端标题行”功能固定我们需要的部分(这里我们选择表头部分也就是打印之后每页开头都会显示的部分),至于固定表尾Excel中没有类似固定表头那样的功能,我们还是采用页眉页脚的方法或者使用VBA宏来实现这个功能。好了,教程如下,有此需求的各位朋友不妨参考下。

什么是表头?

即表格中的第一个单元格。每张调查表按惯例总要有被调查者的简况反映,如被调查者的性别、年龄、学历、收入、家庭成员组成、政治背景、经济状况等。这类问题一般排列在调查表开头部分,称“表头”。

如何打印固定表头

①启动Excel2013,打开准备好的数据源,然后单击菜单栏--“页面布局”,单击“页面设置”选项卡里面的红色方框标记按钮。

Excel2013表格中如何打印固定的表头和表尾?

②切换到工作表标签,在打印标题中我们可以看到顶端标题行这一选项,点击右侧的按钮。

Excel2013表格中如何打印固定的表头和表尾?

③这时会返回到表格主页面,我们选中表头部分,也就是你想要每页开头都显示的部分。

Excel2013表格中如何打印固定的表头和表尾?

④确定,我们打印出来看看效果,每一页都显示了刚才选中的部分,实现了打印固定表头的目的。

Excel2013表格中如何打印固定的表头和表尾?

什么是表尾?

与表头类似,是表格中最后的部分,一般都记录了作者所写的备注信息。

如何打印固定表尾

由于Excel没有类似打印固定表头那样的功能,所以我们普遍使用的还是页眉页脚的方法,这个方法简单实效,或者可以用VBA宏来实现这个功能。

①插入页眉页脚,自定义页脚,在页脚输入框输入表尾内容,当然也可以直接复制粘贴。对于图片的话,我们需要慢慢调整尺寸。

Excel2013表格中如何打印固定的表头和表尾?

②打印看看,每一页都有表尾了。

Excel2013表格中如何打印固定的表头和表尾?

http://www.topdf.cn/pdf-decode

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是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、付费专栏及课程。

余额充值