ブックから OLE オブジェクトを抽出する
Contents
[
Hide
]
場合によっては、ブックから OLE オブジェクトを抽出する必要があります。 Aspose.Cells は、この記事で説明されているように、これらの OLE オブジェクトの抽出と保存をサポートしています。
ブックから OLE オブジェクトを抽出する
テンプレート ワークブックの作成
- Microsoft Excel でスプレッドシートを作成しました。
- 最初のワークシートに Microsoft Word ドキュメント、Excel ワークブック、および PDF ドキュメントを OLE オブジェクトとして追加します。
OLE オブジェクトを抽出する
以下のコードは、OLE オブジェクトを DOCX、XLSX、PPTX、および PDF ファイルとして見つけて抽出する実際の作業を行います。
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-Java | |
// The path to the documents directory. | |
String dataDir = Utils.getDataDir(ExtractOLEObjects.class); | |
// Instantiating a Workbook object, Open the template file. | |
Workbook workbook = new Workbook(dataDir + "oleFile.xlsx"); | |
// Get the OleObject Collection in the first worksheet. | |
OleObjectCollection objects = workbook.getWorksheets().get(0).getOleObjects(); | |
// Loop through all the OleObjects and extract each object in the worksheet. | |
for (int i = 0; i < objects.getCount(); i++) { | |
OleObject object = objects.get(i); | |
// Specify the output filename. | |
String fileName = "D:/object" + i + "."; | |
// Specify each file format based on the OleObject format type. | |
switch (object.getFileFormatType()) { | |
case FileFormatType.DOCX: | |
fileName += "docx"; | |
break; | |
case FileFormatType.XLSX: | |
fileName += "xlsx"; | |
break; | |
case FileFormatType.PPTX: | |
fileName += "pptx"; | |
break; | |
case FileFormatType.PDF: | |
fileName += "pdf"; | |
break; | |
case FileFormatType.UNKNOWN: | |
fileName += "jpg"; | |
break; | |
default: | |
// ........ | |
break; | |
} | |
// Save the OleObject as a new excel file if the object type is xls. | |
if (object.getFileFormatType() == FileFormatType.XLSX) { | |
byte[] bytes = object.getObjectData(); | |
InputStream is = new ByteArrayInputStream(bytes); | |
Workbook oleBook = new Workbook(is); | |
oleBook.getSettings().setHidden(false); | |
oleBook.save(fileName); | |
} | |
// Create the files based on the OleObject format types. | |
else { | |
FileOutputStream fos = new FileOutputStream(fileName); | |
fos.write(object.getObjectData()); | |
fos.close(); | |
} | |
} |
結論:
この記事では、Aspose.Cells を使用してワークブックから OLE オブジェクトを抽出する方法を示します。これらのオプションを独自のシナリオで使用できるようにするための洞察が得られることを願っています。