excel表格打印每页都有表头_Excel怎么能让每一页都打印上相同的顶端和底端标题?...

  日常工作中,经常会有需要一次打印很多页的Excel表格数据的情况,而且要求打印出来的每一页都要有相同的顶端标题和底端标题,这样使得打印出来的Excel表格整齐又美观,主要还是为了方便阅读和对数据进行分析。

  像是资产明细表和商品盘点表这类的表格,往往都会有很多页。那么,在打印的时候,除了每页都必须要有的固定标题外,还要在每页的地步再加上统一的文字内容,比如制表人、审核人以及部门负责人之类的相关信息。 

7273634e3bbeefcd4ff8f0c157ba813e.png

  其实在Excel表格中,已经录入了“顶端和底端”的标题,但是不加设置的话,打印出来的表格中会只在第一页中有“顶端标题”,最后一页中有“底端标题”。这么一来,阅读的时候就不是很方便。

  下面就给大家展示一下,如何设置才能让打印出的来每一页都有同样的“顶端标题和底端标题”。

  步骤一:先找到Excel工作表底部的底端标题文字,然后把这些标题文字截图保存成图片格式,然后把表格中最底部的“底端标题”文字内容去掉。 

3f362640d2045fce4bbca11c5309343d.png

  步骤二:在表格工具栏中点击【页面布局】,在此选项卡下点击【打印标题】,在新弹出的【页面设置】对话框中,选择【工作表】选项卡。在【打印标题】这一栏中的【顶端标题行】编辑框中右【顶端标题行】中输入【$1:$1】,这个按照步骤操作就可以。 

6b869301dd5bd67ba45bb63901bfa709.png
254e878bc8e8158b3b1e07da32356801.png

  步骤三:接着再点击切换到选项卡【页眉/页脚】,点击页面中的【自定义页脚】的按钮,在弹出的【页脚】对话框中,点击中间的【中】编辑框,如果需要把底端标题放到也页面的左边或者右边,也可以点击【左】或者【右】编辑框。然后点击编辑框上方工具栏的【插入图片】按钮,把之前截取的底端标题内容截图,上传到这里,最后,点击下方的【确定】按钮。 

492af0c73d7a6594d0577f49f73f8093.png

  步骤四:这时候还需要再回到【页面设置】的对话框中,切换到选项卡【页边距】中,在【居中方式】的选项处勾选【水平】复选框,还需要把【下边距】设置的大一些,这点非常重要。最后,点击【确定】就大功告成了。 

3c4b77e2c6f0873b469c4d5a2401ff1c.png

  经过以上这四个步骤的设置之后,我们打印出来的每一页都会有相同的【顶端标题】和【底端标题】。大家都学会了吧,这样打印出来的表格数据,在翻看内容的时候就会更加明了,方便多了。

  以上就是今天的全部内容了,希望对大家有所帮助。

以下是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、付费专栏及课程。

余额充值