使用 Java 管理演示文稿中的表格单元格
识别合并的表格单元格
- 创建 Presentation 类的实例。
- 从第一张幻灯片获取表格。
- 遍历表格的行和列以查找合并的单元格。
- 发现合并单元格时打印信息。
以下 Java 代码展示了如何在演示文稿中识别合并的表格单元格:
Presentation pres = new Presentation("SomePresentationWithTable.pptx");
try {
ITable table = (ITable)pres.getSlides().get_Item(0).getShapes().get_Item(0); // 假设 Slide#0.Shape#0 是表格
for (int i = 0; i < table.getRows().size(); i++)
{
for (int j = 0; j < table.getColumns().size(); j++)
{
ICell currentCell = table.getRows().get_Item(i).get_Item(j);
if (currentCell.isMergedCell())
{
System.out.println(String.format("Cell %d;%d is a part of merged cell with RowSpan=%d and ColSpan=%d starting from Cell %d;%d.",
i, j, currentCell.getRowSpan(), currentCell.getColSpan(), currentCell.getFirstRowIndex(), currentCell.getFirstColumnIndex()));
}
}
}
} finally {
if (pres != null) pres.dispose();
}
删除表格单元格边框
- 创建 Presentation 类的实例。
- 通过索引获取幻灯片的引用。
- 定义列宽数组。
- 定义行高数组。
- 通过 addTable 方法向幻灯片添加表格。
- 遍历每个单元格,清除上、下、右、左边框。
- 将修改后的演示文稿保存为 PPTX 文件。
以下 Java 代码展示了如何删除表格单元格的边框:
// 实例化表示 PPTX 文件的 Presentation 类
Presentation pres = new Presentation();
try {
// 访问第一张幻灯片
Slide sld = (Slide)pres.getSlides().get_Item(0);
// 定义列宽和行高
double[] dblCols = { 50, 50, 50, 50 };
double[] dblRows = { 50, 30, 30, 30, 30 };
// 向幻灯片添加表格形状
ITable tbl = sld.getShapes().addTable(100, 50, dblCols, dblRows);
// 为每个单元格设置边框格式
for (IRow row : tbl.getRows())
{
for (ICell cell : row)
{
cell.getCellFormat().getBorderTop().getFillFormat().setFillType(FillType.NoFill);
cell.getCellFormat().getBorderBottom().getFillFormat().setFillType(FillType.NoFill);
cell.getCellFormat().getBorderLeft().getFillFormat().setFillType(FillType.NoFill);
cell.getCellFormat().getBorderRight().getFillFormat().setFillType(FillType.NoFill);
}
}
// 将 PPTX 写入磁盘
pres.save("table_out.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
合并单元格中的编号
如果我们将两个单元格对 (1,1) x (2,1) 和 (1,2) x (2,2) 合并,生成的表格将具有编号。以下 Java 代码演示了该过程:
// 实例化表示 PPTX 文件的 Presentation 类
Presentation pres = new Presentation();
try {
// 访问第一张幻灯片
ISlide sld = pres.getSlides().get_Item(0);
// 定义列宽和行高
double[] dblCols = { 70, 70, 70, 70 };
double[] dblRows = { 70, 70, 70, 70 };
// 向幻灯片添加表格形状
ITable tbl = sld.getShapes().addTable(100, 50, dblCols, dblRows);
// 为每个单元格设置边框格式
for (IRow row : tbl.getRows())
{
for (ICell cell : row)
{
cell.getCellFormat().getBorderTop().getFillFormat().setFillType(FillType.Solid);
cell.getCellFormat().getBorderTop().getFillFormat().getSolidFillColor().setColor(Color.RED);
cell.getCellFormat().getBorderTop().setWidth(5);
cell.getCellFormat().getBorderBottom().getFillFormat().setFillType(FillType.Solid);
cell.getCellFormat().getBorderBottom().getFillFormat().getSolidFillColor().setColor(Color.RED);
cell.getCellFormat().getBorderBottom().setWidth(5);
cell.getCellFormat().getBorderLeft().getFillFormat().setFillType(FillType.Solid);
cell.getCellFormat().getBorderLeft().getFillFormat().getSolidFillColor().setColor(Color.RED);
cell.getCellFormat().getBorderLeft().setWidth(5);
cell.getCellFormat().getBorderRight().getFillFormat().setFillType(FillType.Solid);
cell.getCellFormat().getBorderRight().getFillFormat().getSolidFillColor().setColor(Color.RED);
cell.getCellFormat().getBorderRight().setWidth(5);
}
}
// 合并单元格 (1, 1) x (2, 1)
tbl.mergeCells(tbl.get_Item(1, 1), tbl.get_Item(2, 1), false);
// 合并单元格 (1, 2) x (2, 2)
tbl.mergeCells(tbl.get_Item(1, 2), tbl.get_Item(2, 2), false);
pres.save("MergeCells_out.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
然后我们进一步合并单元格,合并 (1,1) 和 (1,2)。结果是表格中心出现一个大型合并单元格:
// 实例化表示 PPTX 文件的 Presentation 类
Presentation pres = new Presentation();
try {
// 访问第一张幻灯片
ISlide sld = pres.getSlides().get_Item(0);
// 定义列宽和行高
double[] dblCols = { 70, 70, 70, 70 };
double[] dblRows = { 70, 70, 70, 70 };
// 向幻灯片添加表格形状
ITable tbl = sld.getShapes().addTable(100, 50, dblCols, dblRows);
// 为每个单元格设置边框格式
for (IRow row : tbl.getRows())
{
for (ICell cell : row)
{
cell.getCellFormat().getBorderTop().getFillFormat().setFillType(FillType.Solid);
cell.getCellFormat().getBorderTop().getFillFormat().getSolidFillColor().setColor(Color.RED);
cell.getCellFormat().getBorderTop().setWidth(5);
cell.getCellFormat().getBorderBottom().getFillFormat().setFillType(FillType.Solid);
cell.getCellFormat().getBorderBottom().getFillFormat().getSolidFillColor().setColor(Color.RED);
cell.getCellFormat().getBorderBottom().setWidth(5);
cell.getCellFormat().getBorderLeft().getFillFormat().setFillType(FillType.Solid);
cell.getCellFormat().getBorderLeft().getFillFormat().getSolidFillColor().setColor(Color.RED);
cell.getCellFormat().getBorderLeft().setWidth(5);
cell.getCellFormat().getBorderRight().getFillFormat().setFillType(FillType.Solid);
cell.getCellFormat().getBorderRight().getFillFormat().getSolidFillColor().setColor(Color.RED);
cell.getCellFormat().getBorderRight().setWidth(5);
}
}
// 合并单元格 (1, 1) x (2, 1)
tbl.mergeCells(tbl.get_Item(1, 1), tbl.get_Item(2, 1), false);
// 合并单元格 (1, 2) x (2, 2)
tbl.mergeCells(tbl.get_Item(1, 2), tbl.get_Item(2, 2), false);
// 合并单元格 (1, 1) x (1, 2)
tbl.mergeCells(tbl.get_Item(1, 1), tbl.get_Item(1, 2), true);
// 将 PPTX 文件写入磁盘
pres.save("MergeCells_out.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
拆分单元格中的编号
在之前的示例中,当表格单元格合并时,其他单元格的编号或编号系统保持不变。
这一次,我们使用一个常规表格(没有合并单元格的表格),尝试拆分单元格 (1,1) 来得到一个特殊的表格。您可能需要注意该表格的编号方式,可能会显得奇怪。不过,这正是 Microsoft PowerPoint 对表格单元格进行编号的方式,Aspose.Slides 也采用相同的实现。
以下 Java 代码演示了我们描述的过程:
// 实例化表示 PPTX 文件的 Presentation 类
Presentation pres = new Presentation();
try {
// 访问第一张幻灯片
ISlide sld = pres.getSlides().get_Item(0);
// 定义列宽和行高
double[] dblCols = { 70, 70, 70, 70 };
double[] dblRows = { 70, 70, 70, 70 };
// 向幻灯片添加表格形状
ITable tbl = sld.getShapes().addTable(100, 50, dblCols, dblRows);
// 为每个单元格设置边框格式
for (IRow row : tbl.getRows())
{
for (ICell cell : row)
{
cell.getCellFormat().getBorderTop().getFillFormat().setFillType(FillType.Solid);
cell.getCellFormat().getBorderTop().getFillFormat().getSolidFillColor().setColor(Color.RED);
cell.getCellFormat().getBorderTop().setWidth(5);
cell.getCellFormat().getBorderBottom().getFillFormat().setFillType(FillType.Solid);
cell.getCellFormat().getBorderBottom().getFillFormat().getSolidFillColor().setColor(Color.RED);
cell.getCellFormat().getBorderBottom().setWidth(5);
cell.getCellFormat().getBorderLeft().getFillFormat().setFillType(FillType.Solid);
cell.getCellFormat().getBorderLeft().getFillFormat().getSolidFillColor().setColor(Color.RED);
cell.getCellFormat().getBorderLeft().setWidth(5);
cell.getCellFormat().getBorderRight().getFillFormat().setFillType(FillType.Solid);
cell.getCellFormat().getBorderRight().getFillFormat().getSolidFillColor().setColor(Color.RED);
cell.getCellFormat().getBorderRight().setWidth(5);
}
}
// 合并单元格 (1, 1) x (2, 1)
tbl.mergeCells(tbl.get_Item(1, 1), tbl.get_Item(2, 1), false);
// 合并单元格 (1, 2) x (2, 2)
tbl.mergeCells(tbl.get_Item(1, 2), tbl.get_Item(2, 2), false);
// 拆分单元格 (1, 1)
tbl.get_Item(1, 1).splitByWidth(tbl.get_Item(2, 1).getWidth() / 2);
//将 PPTX 文件写入磁盘
pres.save("SplitCells_out.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
更改表格单元格背景颜色
以下 Java 代码展示了如何更改表格单元格的背景颜色:
Presentation presentation = new Presentation();
try {
ISlide slide = presentation.getSlides().get_Item(0);
double[] dblCols = { 150, 150, 150, 150 };
double[] dblRows = { 50, 50, 50, 50, 50 };
// 创建一个新表格
ITable table = slide.getShapes().addTable(50, 50, dblCols, dblRows);
// 设置单元格的背景颜色
ICell cell = table.get_Item(2, 3);
cell.getCellFormat().getFillFormat().setFillType(FillType.Solid);
cell.getCellFormat().getFillFormat().getSolidFillColor().setColor(Color.RED);
presentation.save("cell_background_color.pptx", SaveFormat.Pptx);
} finally {
if (presentation != null) presentation.dispose();
}
在表格单元格中添加图像
- 创建 Presentation 类的实例。
- 通过索引获取幻灯片的引用。
- 定义列宽数组。
- 定义行高数组。
- 通过 AddTable 方法向幻灯片添加表格。
- 创建
Images对象以保存图像文件。 - 将
IImage图像添加到IPPImage对象。 - 将表格单元格的
FillFormat设置为Picture。 - 将图像添加到表格的第一个单元格。
- 将修改后的演示文稿保存为 PPTX 文件
以下 Java 代码展示了在创建表格时如何将图像放置在表格单元格中:
// 实例化表示 PPTX 文件的 Presentation 类
Presentation pres = new Presentation();
try {
// 访问第一张幻灯片
ISlide islide = pres.getSlides().get_Item(0);
// 定义列宽和行高
double[] dblCols = {150, 150, 150, 150};
double[] dblRows = {100, 100, 100, 100, 90};
// 向幻灯片添加表格形状
ITable tbl = islide.getShapes().addTable(50, 50, dblCols, dblRows);
// 使用图像文件创建 IPPImage 对象
IPPImage picture;
IImage image = Images.fromFile("image.jpg");
try {
picture = pres.getImages().addImage(image);
} finally {
if (image != null) image.dispose();
}
// 将图像添加到第一个表格单元格
ICellFormat cellFormat = tbl.get_Item(0, 0).getCellFormat();
cellFormat.getFillFormat().setFillType(FillType.Picture);
cellFormat.getFillFormat().getPictureFillFormat().setPictureFillMode(PictureFillMode.Stretch);
cellFormat.getFillFormat().getPictureFillFormat().getPicture().setImage(picture);
// 将 PPTX 文件保存到磁盘
pres.save("Image_In_TableCell_out.pptx", SaveFormat.Pptx);
} catch (IOException e) {
} finally {
if (pres != null) pres.dispose();
}
常见问题
我可以为单个单元格的不同侧设置不同的线条粗细和样式吗?
可以。单元格的 top、bottom、left、right 边框拥有独立的属性,因此每一侧的粗细和样式可以不同。这与文章中展示的对单元格的每侧边框控制逻辑相符。
如果在将图片设为单元格背景后更改列/行大小,会发生什么?
行为取决于 fill mode(拉伸/平铺)。拉伸时,图像会适应新的单元格;平铺时,平铺块会重新计算。文章中提到了单元格内图像的显示模式。
我可以为单元格的全部内容分配超链接吗?
Hyperlinks 在单元格的文本框内的文本(段落)级别或整个表格/形状级别设置。实际操作中,您可以将链接分配给段落或整个单元格的所有文本。
我可以在单个单元格内设置不同的字体吗?
可以。单元格的文本框支持具有独立格式的 portions(文本段),包括字体系列、样式、大小和颜色。