チャートワークブック
ワークブックからチャートデータを設定する
Aspose.Slidesは、チャートデータワークブック(Aspose.Cellsで編集されたチャートデータを含む)を読み書きすることができるReadWorkbookStreamおよびWriteWorkbookStreamメソッドを提供します。注意:チャートデータは、同じ方法で整理されるか、ソースに類似した構造を持つ必要があります。
このJavaコードは、サンプル操作を示しています:
Presentation pres = new Presentation("chart.pptx");
try {
Chart chart = (Chart) pres.getSlides().get_Item(0).getShapes().get_Item(0);
IChartData data = chart.getChartData();
byte[] stream = data.readWorkbookStream();
data.getSeries().clear();
data.getCategories().clear();
data.writeWorkbookStream(stream);
} finally {
if (pres != null) pres.dispose();
}
ワークブックセルをチャートデータラベルとして設定する
1. Presentation クラスのインスタンスを作成します。
- インデックスを介してスライドの参照を取得します。
- データを持つバブルチャートを追加します。
- チャート系列にアクセスします。
- ワークブックセルをデータラベルとして設定します。
- プレゼンテーションを保存します。
このJavaコードは、ワークブックセルをチャートデータラベルとして設定する方法を示しています:
String lbl0 = "ラベル0のセル値";
String lbl1 = "ラベル1のセル値";
String lbl2 = "ラベル2のセル値";
// プレゼンテーションファイルを表すPresentationクラスのインスタンスを作成
Presentation pres = new Presentation("chart2.pptx");
try {
ISlide slide = pres.getSlides().get_Item(0);
IChart chart = slide.getShapes().addChart(ChartType.Bubble, 50, 50, 600, 400, true);
IChartSeriesCollection series = chart.getChartData().getSeries();
IDataLabelCollection dataLabelCollection = series.get_Item(0).getLabels();
dataLabelCollection.getDefaultDataLabelFormat().setShowLabelValueFromCell(true);
IChartDataWorkbook wb = chart.getChartData().getChartDataWorkbook();
dataLabelCollection.get_Item(0).setValueFromCell(wb.getCell(0, "A10", lbl0));
dataLabelCollection.get_Item(1).setValueFromCell(wb.getCell(0, "A11", lbl1));
dataLabelCollection.get_Item(2).setValueFromCell(wb.getCell(0, "A12", lbl2));
pres.save("resultchart.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
ワークシートを管理する
このJavaコードは、IChartDataWorkbook.Worksheetsメソッドを使用してワークシートコレクションにアクセスする操作を示しています:
Presentation pres = new Presentation();
try {
IChart chart = pres.getSlides().get_Item(0).getShapes().addChart(ChartType.Pie, 50, 50, 400, 500);
IChartDataWorkbook wb = chart.getChartData().getChartDataWorkbook();
for (int i = 0; i < wb.getWorksheets().size(); i++)
System.out.println(wb.getWorksheets().get_Item(i).getName());
} finally {
if (pres != null) pres.dispose();
}
データソースのタイプを指定する
このJavaコードは、データソースのタイプを指定する方法を示しています:
Presentation pres = new Presentation();
try {
IChart chart = pres.getSlides().get_Item(0).getShapes().addChart(ChartType.Column3D, 50, 50, 600, 400, true);
IStringChartValue val = chart.getChartData().getSeries().get_Item(0).getName();
val.setDataSourceType(DataSourceType.StringLiterals);
val.setData("リテラル文字列");
val = chart.getChartData().getSeries().get_Item(1).getName();
val.setData(chart.getChartData().getChartDataWorkbook().getCell(0, "B1", "NewCell"));
pres.save("pres.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
外部ワークブック
外部ワークブックを作成する
**readWorkbookStream
およびsetExternalWorkbook
**メソッドを使用して、外部ワークブックをゼロから作成するか、内部ワークブックを外部にすることができます。
このJavaコードは外部ワークブック作成プロセスを示しています:
Presentation pres = new Presentation();
try {
final String workbookPath = "externalWorkbook1.xlsx";
IChart chart = pres.getSlides().get_Item(0).getShapes().addChart(ChartType.Pie, 50, 50, 400, 600);
FileOutputStream fileStream = new FileOutputStream(workbookPath);
try {
byte[] workbookData = chart.getChartData().readWorkbookStream();
fileStream.write(workbookData, 0, workbookData.length);
} finally {
if (fileStream != null) fileStream.close();
}
chart.getChartData().setExternalWorkbook(workbookPath);
pres.save("externalWorkbook.pptx", SaveFormat.Pptx);
} catch (IOException e) {
} finally {
if (pres != null) pres.dispose();
}
外部ワークブックを設定する
**setExternalWorkbook
**メソッドを使用して、チャートに外部ワークブックをデータソースとして割り当てることができます。このメソッドは、外部ワークブックのパスを更新するためにも使用できます(後で移動された場合)。
リモートの場所やリソースに保存されているワークブックのデータを編集することはできませんが、そのようなワークブックを外部データソースとして使用することはできます。外部ワークブックの相対パスが提供されると、自動的にフルパスに変換されます。
このJavaコードは外部ワークブックを設定する方法を示しています:
// Presentationクラスのインスタンスを作成
Presentation pres = new Presentation("chart.pptx");
try {
IChart chart = pres.getSlides().get_Item(0).getShapes().addChart(ChartType.Pie, 50, 50, 400, 600, false);
IChartData chartData = chart.getChartData();
chartData.setExternalWorkbook("externalWorkbook.xlsx");
chartData.getSeries().add(chartData.getChartDataWorkbook().getCell(0, "B1"), ChartType.Pie);
chartData.getSeries().get_Item(0).getDataPoints().addDataPointForPieSeries(chartData.getChartDataWorkbook().getCell(0, "B2"));
chartData.getSeries().get_Item(0).getDataPoints().addDataPointForPieSeries(chartData.getChartDataWorkbook().getCell(0, "B3"));
chartData.getSeries().get_Item(0).getDataPoints().addDataPointForPieSeries(chartData.getChartDataWorkbook().getCell(0, "B4"));
chartData.getCategories().add(chartData.getChartDataWorkbook().getCell(0, "A2"));
chartData.getCategories().add(chartData.getChartDataWorkbook().getCell(0, "A3"));
chartData.getCategories().add(chartData.getChartDataWorkbook().getCell(0, "A4"));
pres.save("Presentation_with_externalWorkbook.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
setExternalWorkbook
メソッドのChartData
パラメータは、Excelワークブックが読み込まれるかどうかを指定するために使用されます。
ChartData
の値がfalse
に設定されている場合、ワークブックパスのみが更新されます—チャートデータは読み込まれないか、更新されません。この設定は、ターゲットワークブックが存在しないか、利用できない場合に使用することをお勧めします。ChartData
の値がtrue
に設定されている場合、ターゲットワークブックからチャートデータが更新されます。
// Presentationクラスのインスタンスを作成
Presentation pres = new Presentation("chart.pptx");
try {
IChart chart = pres.getSlides().get_Item(0).getShapes().addChart(ChartType.Pie, 50, 50, 400, 600, true);
IChartData chartData = chart.getChartData();
((ChartData)chartData).setExternalWorkbook("http://path/doesnt/exists", false);
pres.save("Presentation_with_externalWorkbookWithUpdateChartData.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
チャート外部データソースのワークブックパスを取得する
1. Presentation クラスのインスタンスを作成します。
- インデックスを介してスライドの参照を取得します。
- チャートシェイプのオブジェクトを作成します。
- チャートのデータソースを表す
ChartDataSourceType
タイプのオブジェクトを作成します。 - ソースタイプが外部ワークブックデータソースタイプと同じである場合に基づいて関連条件を指定します。
このJavaコードは、操作を示しています:
// Presentationクラスのインスタンスを作成
Presentation pres = new Presentation("chart.pptx");
try {
ISlide slide = pres.getSlides().get_Item(1);
IChart chart = (IChart)slide.getShapes().get_Item(0);
int sourceType = chart.getChartData().getDataSourceType();
if (sourceType == ChartDataSourceType.ExternalWorkbook)
{
String path = chart.getChartData().getExternalWorkbookPath();
}
// プレゼンテーションを保存
pres.save("result.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
チャートデータを編集する
外部ワークブックのデータは、内部ワークブックの内容を変更するのと同じ方法で編集できます。外部ワークブックを読み込めない場合は、例外がスローされます。
このJavaコードは、記述されたプロセスの実装です:
// Presentationクラスのインスタンスを作成
Presentation pres = new Presentation("chart.pptx");
try {
IChart chart = (IChart)pres.getSlides().get_Item(0).getShapes().get_Item(0);
ChartData chartData = (ChartData)chart.getChartData();
chartData.getSeries().get_Item(0).getDataPoints().get_Item(0).getValue().getAsCell().setValue(100);
pres.save("presentation_out.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}