チャート ワークブック
ワークブックからチャート データを設定
Aspose.Slides は、readWorkbookStream および writeWorkbookStream メソッドを提供し、チャート データ ワークブック(Aspose.Cells で編集されたチャート データを含む)を読み書きできます。注: チャート データは同じ形式で構成されているか、元と同様の構造である必要があります。
この JavaScript コードはサンプル操作を示します:
var pres = new aspose.slides.Presentation("chart.pptx");
try {
var chart = pres.getSlides().get_Item(0).getShapes().get_Item(0);
var data = chart.getChartData();
var stream = data.readWorkbookStream();
data.getSeries().clear();
data.getCategories().clear();
data.writeWorkbookStream(stream);
} finally {
if (pres != null) {
pres.dispose();
}
}
ワークブック セルをチャート データ ラベルとして設定
- Presentation クラスのインスタンスを作成します。
- インデックスを使用してスライドの参照を取得します。
- データを含むバブル チャートを追加します。
- チャート シリーズにアクセスします。
- ワークブック セルをデータ ラベルとして設定します。
- プレゼンテーションを保存します。
この JavaScript コードは、ワークブック セルをチャート データ ラベルとして設定する方法を示します:
var lbl0 = "Label 0 cell value";
var lbl1 = "Label 1 cell value";
var lbl2 = "Label 2 cell value";
// プレゼンテーション ファイルを表すプレゼンテーション クラスのインスタンスを作成します
var pres = new aspose.slides.Presentation("chart2.pptx");
try {
var slide = pres.getSlides().get_Item(0);
var chart = slide.getShapes().addChart(aspose.slides.ChartType.Bubble, 50, 50, 600, 400, true);
var series = chart.getChartData().getSeries();
var dataLabelCollection = series.get_Item(0).getLabels();
dataLabelCollection.getDefaultDataLabelFormat().setShowLabelValueFromCell(true);
var 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", aspose.slides.SaveFormat.Pptx);
} finally {
if (pres != null) {
pres.dispose();
}
}
ワークシートの管理
この JavaScript コードは、ChartDataWorkbook.getWorksheets メソッドを使用してワークシート コレクションにアクセスする操作を示します:
var pres = new aspose.slides.Presentation();
try {
var chart = pres.getSlides().get_Item(0).getShapes().addChart(aspose.slides.ChartType.Pie, 50, 50, 400, 500);
var wb = chart.getChartData().getChartDataWorkbook();
for (var i = 0; i < wb.getWorksheets().size(); i++) {
console.log(wb.getWorksheets().get_Item(i).getName());
}
} finally {
if (pres != null) {
pres.dispose();
}
}
データ ソース タイプの指定
この JavaScript コードは、データ ソースのタイプを指定する方法を示します:
var pres = new aspose.slides.Presentation();
try {
var chart = pres.getSlides().get_Item(0).getShapes().addChart(aspose.slides.ChartType.Column3D, 50, 50, 600, 400, true);
var val = chart.getChartData().getSeries().get_Item(0).getName();
val.setDataSourceType(aspose.slides.DataSourceType.StringLiterals);
val.setData("LiteralString");
val = chart.getChartData().getSeries().get_Item(1).getName();
val.setData(chart.getChartData().getChartDataWorkbook().getCell(0, "B1", "NewCell"));
pres.save("pres.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
if (pres != null) {
pres.dispose();
}
}
外部ワークブック
外部ワークブックの作成
readWorkbookStream と setExternalWorkbook メソッドを使用すると、外部ワークブックを新規作成するか、既存の内部ワークブックを外部化できます。
この JavaScript コードは外部ワークブックの作成プロセスを示します:
var pres = new aspose.slides.Presentation();
try {
final var workbookPath = "externalWorkbook1.xlsx";
var chart = pres.getSlides().get_Item(0).getShapes().addChart(aspose.slides.ChartType.Pie, 50, 50, 400, 600);
var fileStream = java.newInstanceSync("java.io.FileOutputStream", workbookPath);
try {
var workbookData = chart.getChartData().readWorkbookStream();
fileStream.write(workbookData, 0, workbookData.length);
} finally {
if (fileStream != null) {
fileStream.close();
}
}
chart.getChartData().setExternalWorkbook(workbookPath);
pres.save("externalWorkbook.pptx", aspose.slides.SaveFormat.Pptx);
} catch (e) {console.log(e);
} finally {
if (pres != null) {
pres.dispose();
}
}
外部ワークブックの設定
setExternalWorkbook メソッドを使用して、外部ワークブックをチャートのデータ ソースとして割り当てられます。このメソッドは、外部ワークブックのパスが移動された場合などにパスを更新する際にも使用できます。
リモート ロケーションやリソースに保存されているワークブックのデータを直接編集することはできませんが、外部データ ソースとして使用できます。相対パスが指定された場合、フル パスに自動変換されます。
この JavaScript コードは外部ワークブックの設定方法を示します:
// Presentation クラスのインスタンスを作成します
var pres = new aspose.slides.Presentation("chart.pptx");
try {
var chart = pres.getSlides().get_Item(0).getShapes().addChart(aspose.slides.ChartType.Pie, 50, 50, 400, 600, false);
var chartData = chart.getChartData();
chartData.setExternalWorkbook("externalWorkbook.xlsx");
chartData.getSeries().add(chartData.getChartDataWorkbook().getCell(0, "B1"), aspose.slides.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", aspose.slides.SaveFormat.Pptx);
} finally {
if (pres != null) {
pres.dispose();
}
}
ChartData パラメーター(setExternalWorkbook メソッドの下)は、Excel ワークブックをロードするかどうかを指定するために使用されます。
ChartDataの値がfalseに設定されている場合、ワークブック パスのみが更新され、チャート データはターゲット ワークブックから読み込まれません。ターゲット ワークブックが存在しない、または利用できない状況でこの設定を使用できます。ChartDataの値がtrueに設定されている場合、チャート データはターゲット ワークブックから更新されます。
// Presentation クラスのインスタンスを作成します
var pres = new aspose.slides.Presentation("chart.pptx");
try {
var chart = pres.getSlides().get_Item(0).getShapes().addChart(aspose.slides.ChartType.Pie, 50, 50, 400, 600, true);
var chartData = chart.getChartData();
chartData.setExternalWorkbook("http://path/doesnt/exists", false);
pres.save("Presentation_with_externalWorkbookWithUpdateChartData.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
if (pres != null) {
pres.dispose();
}
}
チャート外部データ ソース ワークブック パスの取得
- Presentation クラスのインスタンスを作成します。
- インデックスを使用してスライドの参照を取得します。
- チャート シェイプ用のオブジェクトを作成します。
- チャートのデータ ソースを表すソース (
ChartDataSourceType) オブジェクトを作成します。 - ソース タイプが外部ワークブック データ ソース タイプと同じであることを条件として指定します。
この JavaScript コードは操作を示します:
// Presentation クラスのインスタンスを作成します
var pres = new aspose.slides.Presentation("chart.pptx");
try {
var slide = pres.getSlides().get_Item(1);
var chart = slide.getShapes().get_Item(0);
var sourceType = chart.getChartData().getDataSourceType();
if (sourceType == aspose.slides.ChartDataSourceType.ExternalWorkbook) {
var path = chart.getChartData().getExternalWorkbookPath();
}
// プレゼンテーションを保存します
pres.save("result.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
if (pres != null) {
pres.dispose();
}
}
チャート データの編集
外部ワークブックのデータは、内部ワークブックの内容を変更するのと同じ方法で編集できます。外部ワークブックをロードできない場合、例外がスローされます。
この JavaScript コードは上記プロセスの実装例です:
// Presentation クラスのインスタンスを作成します
var pres = new aspose.slides.Presentation("chart.pptx");
try {
var chart = pres.getSlides().get_Item(0).getShapes().get_Item(0);
var chartData = chart.getChartData();
chartData.getSeries().get_Item(0).getDataPoints().get_Item(0).getValue().getAsCell().setValue(100);
pres.save("presentation_out.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
if (pres != null) {
pres.dispose();
}
}
FAQ
特定のチャートが外部ワークブックにリンクされているか、埋め込みワークブックにリンクされているかを判別できますか?
はい。チャートには データ ソース タイプ と 外部ワークブックへのパス があり、ソースが外部ワークブックの場合はフル パスを取得して外部ファイルが使用されているか確認できます。
外部ワークブックへの相対パスはサポートされていますか? どのように保存されますか?
はい。相対パスを指定すると自動的に絶対パスに変換されます。これによりプロジェクトのポータビリティが向上しますが、プレゼンテーションは PPTX ファイル内に絶対パスを保存します。
ネットワーク リソース/共有上にあるワークブックを使用できますか?
はい、そのようなワークブックは外部データ ソースとして使用可能です。ただし、Aspose.Slides からリモート ワークブックを直接編集することはサポートされていません。ソースとしてのみ使用できます。
プレゼンテーション保存時に外部 XLSX が上書きされますか?
いいえ。プレゼンテーションは 外部ファイルへのリンク を保存し、データ読み取り時に使用します。保存時に外部ファイル自体は変更されません。
外部ファイルがパスワードで保護されている場合はどうすればよいですか?
Aspose.Slides はリンク時にパスワードを受け付けません。一般的な対策として、事前に保護を解除するか、Aspose.Cells などで復号化したコピーを作成し、そのコピーにリンクします。
複数のチャートが同じ外部ワークブックを参照できますか?
はい。各チャートは独自のリンクを保持します。すべてが同じファイルを指す場合、そのファイルを更新すると次回データが読み込まれる際に各チャートに反映されます。