使用 PHP 管理演示文稿中的表格单元格
识别合并的表格单元格
- 创建 Presentation 类的实例。
- 获取第一张幻灯片中的表格。
- 遍历表格的行和列以查找合并单元格。
- 当找到合并单元格时打印消息。
此 PHP 代码演示了如何在演示文稿中识别合并的表格单元格:
$pres = new Presentation("SomePresentationWithTable.pptx");
try {
$table = $pres->getSlides()->get_Item(0)->getShapes()->get_Item(0);// 假设 Slide#0.Shape#0 是一个表格
for($i = 0; $i < java_values($table->getRows()->size()) ; $i++) {
for($j = 0; $j < java_values($table->getColumns()->size()) ; $j++) {
$currentCell = $table->getRows()->get_Item($i)->get_Item($j);
if ($currentCell->isMergedCell()) {
echo(sprintf("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 (!java_is_null($pres)) {
$pres->dispose();
}
}
移除表格单元格边框
- 创建 Presentation 类的实例。
- 通过索引获取幻灯片的引用。
- 定义一个包含列宽的数组。
- 定义一个包含行高的数组。
- 通过 addTable 方法向幻灯片添加表格。
- 遍历每个单元格并清除上、下、右、左四个边框。
- 将修改后的演示文稿保存为 PPTX 文件。
此 PHP 代码演示了如何移除表格单元格的边框:
# 实例化表示 PPTX 文件的 Presentation 类
$pres = new Presentation();
try {
# 访问第一张幻灯片
$sld = $pres->getSlides()->get_Item(0);
# 定义列宽和行高
$dblCols = array(50, 50, 50, 50 );
$dblRows = array(50, 30, 30, 30, 30 );
# 向幻灯片添加表格形状
$tbl = $sld->getShapes()->addTable(100, 50, $dblCols, $dblRows);
# 为每个单元格设置边框格式
foreach($tbl->getRows() as $row) {
foreach($row as $cell) {
$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 (!java_is_null($pres)) {
$pres->dispose();
}
}
合并单元格中的编号
如果我们合并两个单元格对 (1,1)×(2,1) 和 (1,2)×(2,2),生成的表格将会进行编号。以下 PHP 代码展示了该过程:
# 实例化表示 PPTX 文件的 Presentation 类
$pres = new Presentation();
try {
# 访问第一张幻灯片
$sld = $pres->getSlides()->get_Item(0);
# 定义列宽和行高
$dblCols = array(70, 70, 70, 70 );
$dblRows = array(70, 70, 70, 70 );
# 向幻灯片添加表格形状
$tbl = $sld->getShapes()->addTable(100, 50, $dblCols, $dblRows);
# 为每个单元格设置边框格式
foreach($tbl->getRows() as $row) {
foreach($row as $cell) {
$cell->getCellFormat()->getBorderTop()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderTop()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderTop()->setWidth(5);
$cell->getCellFormat()->getBorderBottom()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderBottom()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderBottom()->setWidth(5);
$cell->getCellFormat()->getBorderLeft()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderLeft()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderLeft()->setWidth(5);
$cell->getCellFormat()->getBorderRight()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderRight()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.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 (!java_is_null($pres)) {
$pres->dispose();
}
}
随后我们进一步合并单元格,将 (1,1) 与 (1,2) 合并。结果是表格中心出现一个大的合并单元格:
# 实例化表示 PPTX 文件的 Presentation 类
$pres = new Presentation();
try {
# 访问第一张幻灯片
$sld = $pres->getSlides()->get_Item(0);
# 定义列宽和行高
$dblCols = array(70, 70, 70, 70 );
$dblRows = array(70, 70, 70, 70 );
# 向幻灯片添加表格形状
$tbl = $sld->getShapes()->addTable(100, 50, $dblCols, $dblRows);
# 为每个单元格设置边框格式
foreach($tbl->getRows() as $row) {
foreach($row as $cell) {
$cell->getCellFormat()->getBorderTop()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderTop()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderTop()->setWidth(5);
$cell->getCellFormat()->getBorderBottom()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderBottom()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderBottom()->setWidth(5);
$cell->getCellFormat()->getBorderLeft()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderLeft()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderLeft()->setWidth(5);
$cell->getCellFormat()->getBorderRight()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderRight()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.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 (!java_is_null($pres)) {
$pres->dispose();
}
}
拆分单元格中的编号
在前面的示例中,表格单元格合并后,其他单元格的编号体系保持不变。
这次我们使用一个普通表格(没有合并单元格),然后尝试拆分单元格 (1,1) 以得到一个特殊的表格。请注意此表格的编号方式,可能看起来很奇怪。但这正是 Microsoft PowerPoint 对表格单元格的编号方式,Aspose.Slides 也采用了相同的规则。
以下 PHP 代码演示了我们刚才描述的过程:
# 实例化表示 PPTX 文件的 Presentation 类
$pres = new Presentation();
try {
# 访问第一张幻灯片
$sld = $pres->getSlides()->get_Item(0);
# 定义列宽和行高
$dblCols = array(70, 70, 70, 70 );
$dblRows = array(70, 70, 70, 70 );
# 向幻灯片添加表格形状
$tbl = $sld->getShapes()->addTable(100, 50, $dblCols, $dblRows);
# 为每个单元格设置边框格式
foreach($tbl->getRows() as $row) {
foreach($row as $cell) {
$cell->getCellFormat()->getBorderTop()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderTop()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderTop()->setWidth(5);
$cell->getCellFormat()->getBorderBottom()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderBottom()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderBottom()->setWidth(5);
$cell->getCellFormat()->getBorderLeft()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderLeft()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderLeft()->setWidth(5);
$cell->getCellFormat()->getBorderRight()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderRight()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.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 (!java_is_null($pres)) {
$pres->dispose();
}
}
更改表格单元格背景颜色
此 PHP 代码演示了如何更改表格单元格的背景颜色:
$presentation = new Presentation();
try {
$slide = $presentation->getSlides()->get_Item(0);
$dblCols = array(150, 150, 150, 150 );
$dblRows = array(50, 50, 50, 50, 50 );
# 创建新表格
$table = $slide->getShapes()->addTable(50, 50, $dblCols, $dblRows);
# 为单元格设置背景颜色
$cell = $table->get_Item(2, 3);
$cell->getCellFormat()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$presentation->save("cell_background_color.pptx", SaveFormat::Pptx);
} finally {
if (!java_is_null($presentation)) {
$presentation->dispose();
}
}
在表格单元格中添加图像
- 创建 Presentation 类的实例。
- 通过索引获取幻灯片的引用。
- 定义一个包含列宽的数组。
- 定义一个包含行高的数组。
- 通过 AddTable 方法向幻灯片添加表格。
- 创建
Images对象以保存图像文件。 - 将
IImage图像添加到IPPImage对象。 - 将单元格的
FillFormat设置为Picture。 - 将图像添加到表格的第一个单元格。
- 将修改后的演示文稿保存为 PPTX 文件。
此 PHP 代码演示了在创建表格时如何将图像放入表格单元格:
# 实例化表示 PPTX 文件的 Presentation 类
$pres = new Presentation();
try {
# 访问第一张幻灯片
$islide = $pres->getSlides()->get_Item(0);
# 定义列宽和行高
$dblCols = array(150, 150, 150, 150 );
$dblRows = array(100, 100, 100, 100, 90 );
# 向幻灯片添加表格形状
$tbl = $islide->getShapes()->addTable(50, 50, $dblCols, $dblRows);
# 使用图像文件创建 IPPImage 对象
$picture;
$image = Images->fromFile("image.jpg");
try {
$picture = $pres->getImages()->addImage($image);
} finally {
if (!java_is_null($image)) {
$image->dispose();
}
}
# 将图像添加到表格的第一个单元格
$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 (JavaException $e) {
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
常见问题
我可以为单个单元格的不同边设置不同的线粗细和样式吗?
可以。上、下、左、右四个边框都有各自的属性,因此每一侧的粗细和样式可以不同。这与文中演示的单元格单侧边框控制逻辑一致。
如果在将图片设为单元格背景后更改列/行大小,图片会怎样?
行为取决于 fill mode(拉伸/平铺)。拉伸模式下,图片会随新单元格大小进行调整;平铺模式下,平铺会重新计算。文章中提到了单元格内图片的显示模式。
我可以为单元格的全部内容分配超链接吗?
Hyperlinks 可以在单元格文本框的文本(段落)级别或整个表格/形状级别设置。实际操作中,你可以将链接分配给段落或整个单元格的所有文本。
我可以在单个单元格内使用不同的字体吗?
可以。单元格的文本框支持 portions(文本段)并可以独立设置字体族、样式、大小和颜色。