Spire.Presentation提供了丰富全面的API供程序员对PowerPoint表格进行处理。本文将介绍如何使用该组件创建表格,删除行和列,合并单元格,设置自定义格式和删除表格。
创建表格
C#
//创建一个PowerPoint文档
Presentation ppt = new Presentation();
ppt.SlideSize.Type = SlideSizeType.Screen16x9;
//初始化一个ITable实例,并指定位置、行数和列数、行高和列宽
double[] widths = new double[] { 100, 100, 100, 100 };
double[] heights = new double[] { 15, 15, 15, 15};
ITable table = ppt.Slides[0].Shapes.AppendTable(80, 80, widths, heights);
//为表格设置内置格式
table.StylePreset = TableStylePreset.LightStyle1Accent2;
//声明并初始化一个String[,]数组
string[,] data = new string[,]
{
{"姓名","年龄","性别","工号" },
{"张三","28","男","0023" },
{"李四","30","男","0024" },
{"王五","26","女","0025" }
};
//将数组内容填充到表格
for (int i = 0; i < 4; i++)
{
for (int j = 0; j < 4; j++)
{
table[j, i].TextFrame.Text = data[i, j];
table[j, i].TextFrame.Paragraphs[0].TextRanges[0].LatinFont = new TextFont("Arial");
}
}
//保存文档
ppt.SaveToFile("创建表格.pptx", FileFormat.Pptx2013);
VB.NET
'创建一个PowerPoint文档
Dim ppt As New Presentation()
ppt.SlideSize.Type = SlideSizeType.Screen16x9
'初始化一个ITable实例,并指定位置、行数和列数、行高和列宽
Dim widths As Double() = New Double() {100, 100, 100, 100}
Dim heights As Double() = New Double() {15, 15, 15, 15}
Dim table As ITable = ppt.Slides(0).Shapes.AppendTable(80, 80, widths, heights)
'为表格设置内置格式
table.StylePreset = TableStylePreset.LightStyle1Accent2
'声明并初始化一个String[,]数组
Dim data As String(,) = New String(,) {{"姓名", "年龄", "性别", "工号"}, {"张三", "28", "男", "0023"}, {"李四", "30", "男", "0024"}, {"王五", "26", "女", "0025"}}
'将数组内容填充到表格
For i As Integer = 0 To 3
For j As Integer = 0 To 3
table(j, i).TextFrame.Text = data(i, j)
table(j, i).TextFrame.Paragraphs(0).TextRanges(0).LatinFont = New TextFont("Arial")
Next
Next
'保存文档
ppt.SaveToFile("创建表格.pptx", FileFormat.Pptx2013)
删除行和列
C#
//初始化一个Presentation实例
Presentation ppt = new Presentation();
//加载一个PowerPoint文档
ppt.LoadFromFile("创建表格.pptx");
//获取第一张幻灯片上的表格
ITable table = null;
foreach (IShape shape in ppt.Slides[0].Shapes)
{
if (shape is ITable)
{
table = (ITable)shape;
//删除第三列
table.ColumnsList.RemoveAt(2, false);
//删除第四行
table.TableRows.RemoveAt(3, false);
}
}
//保存文档
ppt.SaveToFile("删除行与列.pptx",FileFormat.Pptx2013);
VB.NET
'初始化一个Presentation实例
Dim ppt As New Presentation()
'加载一个PowerPoint文档
ppt.LoadFromFile("创建表格.pptx")
'获取第一张幻灯片上的表格
Dim table As ITable = Nothing
For Each shape As IShape In ppt.Slides(0).Shapes
If TypeOf shape Is ITable Then
table = DirectCast(shape, ITable)
'删除第三列
table.ColumnsList.RemoveAt(2, False)
'删除第四行
table.TableRows.RemoveAt(3, False)
End If
Next
'保存文档
ppt.SaveToFile("删除行与列.pptx", FileFormat.Pptx2013)
合并单元格、设置单元格格式
C#
//创建一个PowerPoint文档
Presentation ppt = new Presentation();
ppt.SlideSize.Type = SlideSizeType.Screen16x9;
//初始化一个ITable实例,并指定位置、行数和列数、行高和列宽
double[] widths = new double[] { 100, 100, 100, 100 };
double[] heights = new double[] { 15, 15, 15, 15 };
ITable table = ppt.Slides[0].Shapes.AppendTable(80, 80, widths, heights);
//声明并初始化一个String[,]数组
string[,] data = new string[,]
{
{"订单及支付情况","","","" },
{"订单号","日期","客户","是否支付" },
{"1021","2017/5/1","阳光地产","是" },
{"1022","2017/5/2","","否" }
};
//将数组内容填充到表格
for (int i = 0; i < 4; i++)
{
for (int j = 0; j < 4; j++)
{
table[j, i].TextFrame.Text = data[i, j];
table[j, i].TextFrame.Paragraphs[0].TextRanges[0].LatinFont = new TextFont("Arial");
}
}
//将表格的默认格式设为空(自定义表格格式须清除表格默认格式)
table.StylePreset = TableStylePreset.None;
//合并第一行的单元格
for (int i = 0; i < table.ColumnsList.Count-1; i++)
{
Cell cell1 = table[i, 0];
Cell cell2 = table[i+1, 0];
table.MergeCells(cell1, cell2, true);
}
//在合并后新的单元格设置文字水平对齐方式和背景色
Cell newCell1 = table[0, 0];
newCell1.TextFrame.Paragraphs[0].Alignment = TextAlignmentType.Center;
newCell1.FillFormat.FillType = FillFormatType.Solid;
newCell1.FillFormat.SolidColor.Color = System.Drawing.Color.Gray;
//垂直合并单元格[2,2]和单元格[2,3]
Cell cell3 = table[2, 2];
Cell cell4 = table[2, 3];
table.MergeCells(cell3, cell4, true);
//在合并后新的单元格设置文字垂直对齐方式
Cell newCell2 = table[2, 2];
newCell2.TextAnchorType = TextAnchorType.Center;
//为单元格[3,2]、[3,3]设置背景色
Cell cell5 = table[3, 2];
Cell cell6 = table[3, 3];
cell5.FillFormat.FillType = FillFormatType.Solid;
cell6.FillFormat.FillType = FillFormatType.Solid;
cell5.FillFormat.SolidColor.Color = System.Drawing.Color.Green;
cell6.FillFormat.SolidColor.Color = System.Drawing.Color.Red;
//保存文档
ppt.SaveToFile("操作单元格.pptx", FileFormat.Pptx2013);
VB.NET
'创建一个PowerPoint文档
Dim ppt As New Presentation()
ppt.SlideSize.Type = SlideSizeType.Screen16x9
'初始化一个ITable实例,并指定位置、行数和列数、行高和列宽
Dim widths As Double() = New Double() {100, 100, 100, 100}
Dim heights As Double() = New Double() {15, 15, 15, 15}
Dim table As ITable = ppt.Slides(0).Shapes.AppendTable(80, 80, widths, heights)
'声明并初始化一个String[,]数组
Dim data As String(,) = New String(,) {{"订单及支付情况", "", "", ""}, {"订单号", "日期", "客户", "是否支付"}, {"1021", "2017/5/1", "阳光地产", "是"}, {"1022", "2017/5/2", "", "否"}}
'将数组内容填充到表格
For i As Integer = 0 To 3
For j As Integer = 0 To 3
table(j, i).TextFrame.Text = data(i, j)
table(j, i).TextFrame.Paragraphs(0).TextRanges(0).LatinFont = New TextFont("Arial")
Next
Next
'将表格的默认格式设为空(自定义表格格式须清除表格默认格式)
table.StylePreset = TableStylePreset.None
'合并第一行的单元格
For i As Integer = 0 To table.ColumnsList.Count - 2
Dim cell1 As Cell = table(i, 0)
Dim cell2 As Cell = table(i + 1, 0)
table.MergeCells(cell1, cell2, True)
Next
'在合并后新的单元格设置文字水平对齐方式和背景色
Dim newCell1 As Cell = table(0, 0)
newCell1.TextFrame.Paragraphs(0).Alignment = TextAlignmentType.Center
newCell1.FillFormat.FillType = FillFormatType.Solid
newCell1.FillFormat.SolidColor.Color = System.Drawing.Color.Gray
'垂直合并单元格[2,2]和单元格[2,3]
Dim cell3 As Cell = table(2, 2)
Dim cell4 As Cell = table(2, 3)
table.MergeCells(cell3, cell4, True)
'在合并后新的单元格设置文字垂直对齐方式
Dim newCell2 As Cell = table(2, 2)
newCell2.TextAnchorType = TextAnchorType.Center
'为单元格[3,2]、[3,3]设置背景色
Dim cell5 As Cell = table(3, 2)
Dim cell6 As Cell = table(3, 3)
cell5.FillFormat.FillType = FillFormatType.Solid
cell6.FillFormat.FillType = FillFormatType.Solid
cell5.FillFormat.SolidColor.Color = System.Drawing.Color.Green
cell6.FillFormat.SolidColor.Color = System.Drawing.Color.Red
'保存文档
ppt.SaveToFile("操作单元格.pptx", FileFormat.Pptx2013)
删除表格
C#
//初始化一个Presentation实例
Presentation ppt = new Presentation();
//加载一个PowerPoint文档
ppt.LoadFromFile("创建表格.pptx");
//初始化一个List对象,元素类型为IShape
List<IShape> tableShapes= new List<IShape>();
//获取第一张幻灯片上所有的表格图形并添加到List
foreach (IShape shape in ppt.Slides[0].Shapes)
{
if (shape is ITable)
{
tableShapes.Add(shape);
}
}
//从幻灯片删除第一个表格图形
ppt.Slides[0].Shapes.Remove(tableShapes[0]);
//保存文档
ppt.SaveToFile("删除表格.pptx", FileFormat.Pptx2013);
VB.NET
'初始化一个Presentation实例
Dim ppt As New Presentation()
'加载一个PowerPoint文档
ppt.LoadFromFile("创建表格.pptx")
'初始化一个List对象,元素类型为IShape
Dim tableShapes As New List(Of IShape)()
'获取第一张幻灯片上所有的表格图形并添加到List
For Each shape As IShape In ppt.Slides(0).Shapes
If TypeOf shape Is ITable Then
tableShapes.Add(shape)
End If
Next
'从幻灯片删除第一个表格图形
ppt.Slides(0).Shapes.Remove(tableShapes(0))
'保存文档
ppt.SaveToFile("删除表格.pptx", FileFormat.Pptx2013)