在 .NET 中管理演示文稿的图表工作簿
从工作簿读取和写入图表数据
Aspose.Slides 提供了 ReadWorkbookStream 和 WriteWorkbookStream 方法,允许您读取和写入包含使用 Aspose.Cells 编辑的图表数据的工作簿。注意,图表数据必须以相同的方式组织,或具有类似于源的结构。
以下 C# 代码演示了一个示例操作:
using (Presentation pres = new Presentation("chart.pptx"))
{
Chart chart = (Chart) pres.Slides[0].Shapes[0];
IChartData data = chart.ChartData;
MemoryStream stream = data.ReadWorkbookStream();
data.Series.Clear();
data.Categories.Clear();
stream.Position = 0;
data.WriteWorkbookStream(stream);
}
将工作簿单元格设为图表数据标签
- 创建一个 Presentation 类的实例。
- 通过索引获取幻灯片的引用。
- 添加一个带有数据的气泡图。
- 访问图表系列。
- 将工作簿单元格设为数据标签。
- 保存演示文稿。
以下 C# 代码演示如何将工作簿单元格设为图表数据标签:
string lbl0 = "Label 0 cell value";
string lbl1 = "Label 1 cell value";
string lbl2 = "Label 2 cell value";
// 实例化表示演示文件的 Presentation 类
using (Presentation pres = new Presentation("chart2.pptx"))
{
ISlide slide = pres.Slides[0];
IChart chart = pres.Slides[0].Shapes.AddChart(ChartType.Bubble, 50, 50, 600, 400, true);
IChartSeriesCollection series = chart.ChartData.Series;
series[0].Labels.DefaultDataLabelFormat.ShowLabelValueFromCell = true;
IChartDataWorkbook wb = chart.ChartData.ChartDataWorkbook;
series[0].Labels[0].ValueFromCell = wb.GetCell(0, "A10", lbl0);
series[0].Labels[1].ValueFromCell = wb.GetCell(0, "A11", lbl1);
series[0].Labels[2].ValueFromCell = wb.GetCell(0, "A12", lbl2);
pres.Save("resultchart.pptx", Aspose.Slides.Export.SaveFormat.Pptx);
}
管理工作表
以下 C# 代码演示了使用 IChartDataWorkbook.Worksheets 属性访问工作表集合的操作:
using (Presentation pres = new Presentation())
{
IChart chart = pres.Slides[0].Shapes.AddChart(ChartType.Pie, 50, 50, 400, 500);
IChartDataWorkbook wb = chart.ChartData.ChartDataWorkbook;
for (int i = 0; i < wb.Worksheets.Count; i++)
Console.WriteLine(wb.Worksheets[i].Name);
}
指定数据源类型
以下 C# 代码演示如何为数据源指定类型:
using (Presentation pres = new Presentation())
{
IChart chart = pres.Slides[0].Shapes.AddChart(ChartType.Column3D, 50, 50, 600, 400, true);
IStringChartValue val = chart.ChartData.Series[0].Name;
val.DataSourceType = DataSourceType.StringLiterals;
val.Data = "LiteralString";
val = chart.ChartData.Series[1].Name;
val.Data = chart.ChartData.ChartDataWorkbook.GetCell(0, "B1", "NewCell");
pres.Save("pres.pptx", SaveFormat.Pptx);
}
外部工作簿
创建外部工作簿
使用 ReadWorkbookStream 和 SetExternalWorkbook 方法,您可以从头创建外部工作簿,或者将内部工作簿设为外部工作簿。
以下 C# 代码演示外部工作簿的创建过程:
using (Presentation pres = new Presentation())
{
const string workbookPath = "externalWorkbook1.xlsx";
IChart chart = pres.Slides[0].Shapes.AddChart(ChartType.Pie, 50, 50, 400, 600);
using (FileStream fileStream = new FileStream(workbookPath, FileMode.Create))
{
byte[] workbookData = chart.ChartData.ReadWorkbookStream().ToArray();
fileStream.Write(workbookData, 0, workbookData.Length);
}
chart.ChartData.SetExternalWorkbook(Path.GetFullPath(workbookPath));
pres.Save("externalWorkbook.pptx", SaveFormat.Pptx);
}
设置外部工作簿
使用 SetExternalWorkbook 方法,您可以将外部工作簿分配给图表作为其数据源。该方法还可以用于更新外部工作簿的路径(如果后者已移动)。
虽然您无法编辑存储在远程位置或资源中的工作簿数据,但仍可以将此类工作簿用作外部数据源。如果提供了外部工作簿的相对路径,它会自动转换为完整路径。
以下 C# 代码演示如何设置外部工作簿:
// 文档目录的路径。
using (Presentation pres = new Presentation())
{
IChart chart = pres.Slides[0].Shapes.AddChart(ChartType.Pie, 50, 50, 400, 600, false);
IChartData chartData = chart.ChartData;
chartData.SetExternalWorkbook(Path.GetFullPath("externalWorkbook.xlsx"));
chartData.Series.Add(chartData.ChartDataWorkbook.GetCell(0, "B1"), ChartType.Pie);
chartData.Series[0].DataPoints.AddDataPointForPieSeries(chartData.ChartDataWorkbook.GetCell(0, "B2"));
chartData.Series[0].DataPoints.AddDataPointForPieSeries(chartData.ChartDataWorkbook.GetCell(0, "B3"));
chartData.Series[0].DataPoints.AddDataPointForPieSeries(chartData.ChartDataWorkbook.GetCell(0, "B4"));
chartData.Categories.Add(chartData.ChartDataWorkbook.GetCell(0, "A2"));
chartData.Categories.Add(chartData.ChartDataWorkbook.GetCell(0, "A3"));
chartData.Categories.Add(chartData.ChartDataWorkbook.GetCell(0, "A4"));
pres.Save("Presentation_with_externalWorkbook.pptx", SaveFormat.Pptx);
}
SetExternalWorkbook 方法下的 ChartData 参数用于指定是否加载 Excel 工作簿。
- 当
ChartData值设为false时,仅更新工作簿路径——图表数据不会从目标工作簿加载或更新。当目标工作簿不存在或不可用时,您可能需要使用此设置。 - 当
ChartData值设为true时,图表数据将从目标工作簿更新。
using (Presentation pres = new Presentation())
{
IChart chart = pres.Slides[0].Shapes.AddChart(ChartType.Pie, 50, 50, 400, 600, true);
IChartData chartData = chart.ChartData;
(chartData as ChartData).SetExternalWorkbook("http://path/doesnt/exists", false);
pres.Save("SetExternalWorkbookWithUpdateChartData.pptx", SaveFormat.Pptx);
}
获取图表的外部数据源工作簿路径
- 创建一个 Presentation 类的实例。
- 通过索引获取幻灯片的引用。
- 为图表形状创建对象。
- 为表示图表数据源的源(
ChartDataSourceType)类型创建对象。 - 根据源类型与外部工作簿数据源类型相同的情况指定相应的条件。
以下 C# 代码演示此操作:
using (Presentation pres = new Presentation("pres.pptx"))
{
ISlide slide = pres.Slides[1];
IChart chart = (IChart)slide.Shapes[0];
ChartDataSourceType sourceType = chart.ChartData.DataSourceType;
if (sourceType == ChartDataSourceType.ExternalWorkbook)
{
string path = chart.ChartData.ExternalWorkbookPath;
}
// 保存演示文稿
pres.Save("Result.pptx", SaveFormat.Pptx);
}
编辑图表数据
您可以像编辑内部工作簿内容一样编辑外部工作簿中的数据。当外部工作簿无法加载时,会抛出异常。
以下 C# 代码实现了上述过程:
using (Presentation pres = new Presentation("presentation.pptx"))
{
IChart chart = pres.Slides[0].Shapes[0] as IChart;
ChartData chartData = (ChartData)chart.ChartData;
chartData.Series[0].DataPoints[0].Value.AsCell.Value = 100;
pres.Save("presentation_out.pptx", SaveFormat.Pptx);
}
常见问题
我可以确定特定图表是链接到外部工作簿还是嵌入式工作簿吗?
可以。图表具有 数据源类型 和 外部工作簿路径; 如果源是外部工作簿,您可以读取完整路径以确认正在使用外部文件。
是否支持对外部工作簿的相对路径?如果支持,它们是如何存储的?
是的。如果指定相对路径,它会自动转换为绝对路径。这对于项目可移植性很方便;但请注意,演示文稿将在 PPTX 文件中存储绝对路径。
我可以使用位于网络资源/共享上的工作簿吗?
可以,这些工作簿可以用作外部数据源。然而,Aspose.Slides 不支持直接编辑远程工作簿——它们只能作为数据源使用。
在保存演示文稿时,Aspose.Slides 是否会覆盖外部 XLSX 文件?
不会。演示文稿存储对外部文件的 链接,并在读取数据时使用它。保存演示文稿时不会修改外部文件本身。
如果外部文件受密码保护,我该怎么办?
Aspose.Slides 在链接时不接受密码。常见做法是提前移除保护或准备一个已解密的副本(例如,使用 Aspose.Cells),然后链接到该副本。
多个图表可以引用同一个外部工作簿吗?
可以。每个图表都存储自己的链接。如果它们都指向同一文件,更新该文件将在下次加载数据时反映到每个图表中。