-
Java 插入Excel页眉、页脚
前言
在Excel文档中,我们常用页眉页脚来显示文档的附加信息,例如日期、公司名称、Logo或作者信息等。本文将通过Java程序来介绍如何给Excel文档添加页眉页脚。代码示例主要从以下几方面来演示添加方法。
- 添加页眉页脚(文本、图片)
- 为奇偶页添加不同的页眉页脚
- 为首页和其他页添加不同的页眉页脚
在运行代码前,需要添加Jar包到IDEA中。添加方法有两种:其一,在官网上下载Free Spire.XLS for Java产品包,解压后找到lib文件夹下的Spire.Xls.jar,然后手动将其导入IDEA中即可;其二(推荐使用),通过Maven仓库安装导入产品及依赖。创建一个Maven项目,在pom.xml文件中输入以下代码,然后点击“Import Changes”即可。
<repositories> <repository> <id>com.e-iceblue</id> <url>http://repo.e-iceblue.cn/repository/maven-public/</url> </repository> </repositories> <dependencies> <dependency> <groupId>e-iceblue</groupId> <artifactId>spire.xls.free</artifactId> <version>2.2.0</version> </dependency> </dependencies>
代码示例
【示例1】添加页眉、页脚(文本、图片)
Free Spire.XLS for Java支持添加文本、图片到页眉页脚。其中可设置添加位置(靠左、居中、靠右)及文本的字体、字号、颜色等。另外,还需注意Excel页眉或页脚在普通浏览模式下不可见,它们仅在页面布局模式或者打印预览模式才可见。
1 import com.spire.xls.*; 2 import javax.imageio.ImageIO; 3 import java.awt.image.BufferedImage; 4 import java.io.*; 5 6 public class HeaderFooter { 7 public static void main(String[] args) throws IOException { 8 //加载Excel示例文档 9 Workbook workbook= new Workbook(); 10 workbook.loadFromFile("C:\\Users\\Test1\\Desktop\\Test.xlsx"); 11 12 //获取第一个工作表 13 Worksheet Worksheet = workbook.getWorksheets().get(0); 14 15 //添加文本到页眉页脚,并设置其字体、字号、颜色和位置 16 Worksheet.getPageSetup().setRightHeader("&\"微软雅黑\"&14 腾飞广告有限公司"); 17 Worksheet.getPageSetup().setRightFooter("&\"微软雅黑\"&12&B&KFF0000 注:仅用于内部员工查看"); 18 //加载图片 19 BufferedImage image = ImageIO.read( new File("C:\\Users\\Test1\\Desktop\\Image.png")); 20 21 //添加图片到页眉,并设置位置 22 Worksheet.getPageSetup().setLeftHeaderImage(image); 23 Worksheet.getPageSetup().setLeftHeader("&G"); 24 //添加图片到页脚 25 //Worksheet.getPageSetup().setCenterFooterImage(image); 26 //Worksheet.getPageSetup().setCenterFooter("&G"); 27 28 //设置显示样式 29 Worksheet.setViewMode(ViewMode.Layout); 30 31 //保存文档 32 workbook.saveToFile("output/HeaderFooter.xlsx", ExcelVersion.Version2010); 33 } 34 }
添加效果
【示例2】为奇偶页添加不同的页眉页脚
Free Spire.XLS for Java提供了setDifferentOddEven方法来为Excel文档中的奇偶页添加不同的页眉页脚。在添加的同时,可设置文本字体、字号和颜色。
1 import com.spire.xls.*; 2 public class DifferentHeaderFooter { 3 public static void main(String[] args) { 4 5 //加载Excel示例文档 6 Workbook workbook = new Workbook(); 7 workbook.loadFromFile("C:\\Users\\Test1\\Desktop\\Test.xlsx"); 8 9 //获取第一个工作表 10 Worksheet worksheet = workbook.getWorksheets().get(0); 11 12 //设置第一页,第二页 13 worksheet.getCellRange("A1").setText(""); 14 worksheet.getCellRange("M1").setText("第二页"); 15 16 //将setDifferentOddEven的值设为1, 表示奇数页和偶数页可以分别设置页眉页脚 17 worksheet.getPageSetup().setDifferentOddEven((byte)1); 18 19 //设置奇数页及偶数页页眉页脚,样式和颜色 20 worksheet.getPageSetup().setOddHeaderString( "&\"Arial\"&20&B&K191970 奇数_页眉"); 21 worksheet.getPageSetup().setOddFooterString ( "&\"Arial\"&20&B&K191970 奇数_页脚"); 22 worksheet.getPageSetup().setEvenHeaderString ( "&\"Arial\"&20&B&KFF0000 偶数_页眉"); 23 worksheet.getPageSetup().setEvenFooterString ( "&\"Arial\"&20&B&KFF0000 偶数_页脚"); 24 25 //设置显示样式 26 worksheet.setViewMode(ViewMode.Layout); 27 28 //保存文档 29 workbook.saveToFile("output/DifferentHeaderFooter.xlsx", ExcelVersion.Version2010); 30 } 31 }
添加效果
【示例3】为首页和其他页添加不同的页眉页脚
1 import com.spire.xls.*; 2 public class DifferentHeaderFooterOnFirstPage { 3 public static void main(String[] args) { 4 //加载Excel示例文档 5 Workbook workbook = new Workbook(); 6 workbook.loadFromFile("C:\\Users\\Test1\\Desktop\\Test.xlsx"); 7 //获取第一个工作表 8 Worksheet worksheet = workbook.getWorksheets().get(0); 9 10 //设置第一页,第二页 11 worksheet.getCellRange("A1").setText(""); 12 worksheet.getCellRange("M1").setText("第二页"); 13 14 //将setDifferentFirst的值设为1,表示第一页和其他页可分别设置页眉页脚 15 worksheet.getPageSetup().setDifferentFirst((byte)1); 16 17 //设置第一页页眉页脚,样式和颜色 18 worksheet.getPageSetup().setFirstHeaderString("&\"Arial\"&B&20&KFF0000第一页_页眉"); 19 worksheet.getPageSetup().setFirstFooterString("&\"Arial\"&B&20&KFF0000第一页_页脚"); 20 21 //设置其他页的页眉页脚,样式和颜色 22 worksheet.getPageSetup().setCenterHeader("&\"Arial\"&B&20&K191970其它页_页眉"); 23 worksheet.getPageSetup().setCenterFooter("&\"Arial\"&B&20&K191970其它页_页眉"); 24 25 //保存文档 26 workbook.saveToFile("output/DifferentHeaderFooterOnFirstPage.xlsx", ExcelVersion.Version2013); 27 } 28 }
添加效果
总结
通过以上代码示例,我们可以成功地为Excel文档添加页眉页脚,同时,对于一些个性化的需求,我们也可以为奇偶页添加不同的页眉页脚、为首页和其他页添加不同页眉页脚、文字格式化(如,设置字体、字号、字体颜色等)操作。
出 处:https://www.cnblogs.com/Yesi/p/13743262.html
最新更新
python爬虫及其可视化
使用python爬取豆瓣电影短评评论内容
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
uniapp/H5 获取手机桌面壁纸 (静态壁纸)
[前端] DNS解析与优化
为什么在js中需要添加addEventListener()?
JS模块化系统
js通过Object.defineProperty() 定义和控制对象
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比