关于内容概述
本文介绍如何通过Java 程序进行Excel页面设置,如设置页边距、页面大小、页面方向、页面背景、页面缩放比例、打印范围等等。可参考如下方法进行相关代码操作:
关于工具使用
工具使用免费版Spire系列的Excel类库Free Spire.XLS for Java,可自行在中文官网下载jar包,下载后解压将lib文件夹下的Spire.Xls.jar文件导入Java程序(如下图导入结果);Maven程序中的jar导入方法需要配置pom.xml文件,可参考官方教程文档来导入,这里不作赘述。
注意:这里页边距以英寸为单位,在Microsoft Excel中,页边距以厘米为单位。(1 英寸= 2.54 厘米)
Java程序代码示例import com.spire.xls.*;
import javax.imageio.ImageIO;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;
public class PageMargin {
public static void main(String[] args)throws IOException {
//加载测试文档
Workbook workbook = new Workbook();
workbook.loadFromFile("test.xlsx");
//获取第一个工作表
Worksheet sheet = workbook.getWorksheets().get(0);
//设置上下左右页边距
PageSetup pageSetup = sheet.getPageSetup();
pageSetup.setTopMargin(3);
pageSetup.setBottomMargin(2);
pageSetup.setLeftMargin(1);
pageSetup.setRightMargin(1);
//设置页眉页脚页边距
pageSetup.setHeaderMarginInch(2);
pageSetup.setFooterMarginInch(2);
//设置页面方向
pageSetup.setOrientation(PageOrientationType.Landscape);
//设置纸张大小
pageSetup.setPaperSize(PaperSizeType.PaperA4);
//设置页面缩放大小
pageSetup.setZoom(80);
//加载图片,设置成页面背景
BufferedImage image = ImageIO.read( new File("background.png"));
pageSetup.setBackgoundImage(image);
//设置页面打印区域
pageSetup.setPrintArea("A1:I16");
//保存文档
workbook.saveToFile("result.xlsx", ExcelVersion.Version2013);
workbook.dispose();
}
}
页面设置效果:
图1-页面背景
图2-页面方向/缩放比例/纸张大小
图3-页边距
图4-打印区域