Integrate Excel Data into PowerPoint Presentations
Introduction
PowerPoint presentations are a powerful way to display and communicate information. They are often used in conjunction with Excel workbooks, where Excel serves as an excellent source of structured data and PowerPoint excels at visualizing that data for an audience.
There are many practical scenarios where combining Excel and PowerPoint is essential: mail merges, populating data tables, generating one slide per data record (batch slide generation), creating training materials, and consolidating multiple Excel reports into a single presentation, to name a few.
Until now, implementing such features with the Aspose.Slides API required relying on third-party solutions like Aspose.Cells. While these tools are robust, they can be overly complex and costly for users who only need basic data integration functionality.
How It Works
To make working with Excel data easier and more streamlined, Aspose.Slides has introduced a new class for reading data from Excel workbooks. This feature opens up powerful new possibilities for API users who want to leverage Excel as a data source within their presentation workflows.
The new functionality is designed for general-purpose data access and is not integrated into the Presentation Document Object Model (DOM). That means it does not allow editing or saving Excel files — its sole purpose is to open workbooks and navigate through their content to retrieve cell data.
At the core of this feature is the new ExcelDataWorkbook class. This class allows you to load an Excel workbook from a local file or a stream. Once loaded, it provides several overloads of the getCell method, which you can use to retrieve specific cells by their position (e.g., row and column indices or named ranges).
Each call to getCell returns an instance of the ExcelDataCell class. This object represents a single cell in the Excel workbook and gives you access to its value in a simple and intuitive way.
In short, it’s a lightweight and straightforward API for reading Excel data — exactly what many developers need without the overhead of a full spreadsheet processing library.
Let’s Code
Example 1
In the following example, we’ll implement a simple Mail Merge scenario by generating multiple presentations based on data stored in an Excel workbook.
To get started, we need two things:
- An Excel workbook containing the data
- PowerPoint presentation template
// Load the Excel workbook with employee data.
$workbook = new ExcelDataWorkbook("TemplateData.xlsx");
$worksheetIndex = 0;
// Load the presentation template.
$templatePresentation = new Presentation("PresentationTemplate.pptx");
try {
// Loop through Excel rows (excluding header at row 0).
for ($rowIndex = 1; $rowIndex <= 4; $rowIndex++) {
// Create a new presentation for each employee record.
$employeePresentation = new Presentation();
try {
// Remove the default blank slide.
$employeePresentation->getSlides()->removeAt(0);
// Clone the template slide into the new presentation.
$slide = $employeePresentation->getSlides()->addClone($templatePresentation->getSlides()->get_Item(0));
// Get paragraphs from the target shape (assumes shape index 1 is used).
$paragraphs = $slide->getShapes()->get_Item(1)->getTextFrame()->getParagraphs();
// Replace the placeholders with data from Excel.
$employeeName = $workbook->getCell($worksheetIndex, $rowIndex, 0)->getValue()->toString();
$namePortion = $paragraphs->get_Item(0)->getPortions()->get_Item(0);
$namePortion->setText($namePortion->getText()->replace("{{EmployeeName}}", $employeeName));
$department = $workbook->getCell($worksheetIndex, $rowIndex, 1)->getValue()->toString();
$departmentPortion = $paragraphs->get_Item(1)->getPortions()->get_Item(0);
$departmentPortion->setText($departmentPortion->getText()->replace("{{Department}}", $department));
$yearsOfService = $workbook->getCell($worksheetIndex, $rowIndex, 2)->getValue()->toString();
$yearsPortion = $paragraphs->get_Item(2)->getPortions()->get_Item(0);
$yearsPortion->setText($yearsPortion->getText()->replace("{{YearsOfService}}", $yearsOfService));
// Save the personalized presentation to a separate file.
$employeePresentation->save(sprintf("%s Report.pptx", $employeeName), SaveFormat::Pptx);
} finally {
$employeePresentation->dispose();
}
}
} finally {
$templatePresentation->dispose();
}
Example 2
In the second example, we simply copy data from an Excel table and display it on a PowerPoint slide in a more visually appealing format.
In this example, we reuse the same Excel workbook from the first example, which contains a simple employee table.
// Load the Excel workbook containing the employee data.
$workbook = new ExcelDataWorkbook("TemplateData.xlsx");
$worksheetIndex = 0;
// Create a new PowerPoint presentation.
$presentation = new Presentation();
try {
// Add a table shape to the first slide.
$table = $presentation->getSlides()->get_Item(0)->getShapes()->addTable(
50, 200,
array(200, 200, 200),
array(30, 30, 30, 30, 30)
);
// Fill the PowerPoint table with data from the Excel workbook.
for ($rowIndex = 0; $rowIndex < 5; $rowIndex++) {
for ($columnIndex = 0; $columnIndex < 3; $columnIndex++) {
$cellValue = $workbook->getCell($worksheetIndex, $rowIndex, $columnIndex)->getValue()->toString();
$table->getColumns()->get_Item($columnIndex)->get_Item($rowIndex)->getTextFrame()->setText($cellValue);
}
}
// Save the resulting presentation to a file.
$presentation->save("Table.pptx", SaveFormat::Pptx);
} finally {
$presentation->dispose();
}
Summary
This mechanism, available directly in Aspose.Slides, combines working with Excel data and presentations in one place. It allows you to create slides with visual charts and data presented as Excel tables - without any additional libraries or complex integrations.