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:

  1. An Excel workbook containing the data

Excel data example

  1. PowerPoint presentation template

PowerPoint template example

// Load the Excel workbook with employee data.
ExcelDataWorkbook workbook = new ExcelDataWorkbook("TemplateData.xlsx");
int worksheetIndex = 0;

// Load the presentation template.
using Presentation templatePresentation = new Presentation("PresentationTemplate.pptx");

// Loop through Excel rows (excluding header at row 0).
for (int rowIndex = 1; rowIndex <= 4; rowIndex++)
{
    // Create a new presentation for each employee record.
    using Presentation employeePresentation = new Presentation();

    // Remove the default blank slide.
    employeePresentation.Slides.RemoveAt(0);

    // Clone the template slide into the new presentation.
    ISlide slide = employeePresentation.Slides.AddClone(templatePresentation.Slides[0]);

    // Get paragraphs from the target shape (assumes shape index 1 is used).
    IParagraphCollection paragraphs = (slide.Shapes[1] as IAutoShape).TextFrame.Paragraphs;

    // Replace the placeholders with data from Excel.
    string employeeName = workbook.GetCell(worksheetIndex, rowIndex, 0).Value.ToString();
    IPortion namePortion = paragraphs[0].Portions[0];
    namePortion.Text = namePortion.Text.Replace("{{EmployeeName}}", employeeName);

    string department = workbook.GetCell(worksheetIndex, rowIndex, 1).Value.ToString();
    IPortion departmentPortion = paragraphs[1].Portions[0];
    departmentPortion.Text = departmentPortion.Text.Replace("{{Department}}", department);

    string yearsOfService = workbook.GetCell(worksheetIndex, rowIndex, 2).Value.ToString();
    IPortion yearsPortion = paragraphs[2].Portions[0];
    yearsPortion.Text = yearsPortion.Text.Replace("{{YearsOfService}}", yearsOfService);

    // Save the personalized presentation to a separate file.
    employeePresentation.Save($"{employeeName} Report.pptx", SaveFormat.Pptx);
}

Result

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.
ExcelDataWorkbook workbook = new ExcelDataWorkbook("TemplateData.xlsx");
int worksheetIndex = 0;

// Create a new PowerPoint presentation.
using Presentation presentation = new Presentation();

// Add a table shape to the first slide.
ITable table = presentation.Slides[0].Shapes.AddTable(
    50, 200,
    new double[] { 200, 200, 200 },
    new double[] { 30, 30, 30, 30, 30 }
);

// Fill the PowerPoint table with data from the Excel workbook.
for (int rowIndex = 0; rowIndex < 5; rowIndex++)
{
    for (int columnIndex = 0; columnIndex < 3; columnIndex++)
    {
        string cellValue = workbook.GetCell(worksheetIndex, rowIndex, columnIndex).Value.ToString();
        table[columnIndex, rowIndex].TextFrame.Text = cellValue;
    }
}

// Save the resulting presentation to a file.
presentation.Save("Table.pptx", SaveFormat.Pptx);

Result

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.