2

我使用openxml从Web应用程序创建一个PowerPoint。我创建了一个带有图表的ppt并在openxml sdk生产力工具和生成的代码中打开了ppt,我修改了来自数据库的图表数据,我创建的代码将图表数据修改为

为 sdk 中的代码创建了一个类,在 CreatePart() 中我添加了这些链接

 ChartPart chartPart1 = slidePart1.AddNewPart<ChartPart>("rId3");
        GenerateChartPart1Content(chartPart1);
       // This is below code added
        #if true    // Injects the chart part modification process
                    var chartModifier1 = new ChartPartModifier();
                    chartModifier1.UpdateSecondChartPart(chartPart1);
        #endif

        EmbeddedPackagePart embeddedPackagePart1 = chartPart1.AddNewPart<EmbeddedPackagePart>("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", "rId2");
        GenerateEmbeddedPackagePart1Content(embeddedPackagePart1);

并为 ChartPartModifier() 创建了一个类

public void UpdateSecondChartPart(ChartPart chartPart)
    {
        // Searchs SeriesText and its Values to replace them with your dynamic data
        var seriesLabels = chartPart.ChartSpace.Descendants<SeriesText>().ToList();
        var seriesValues = chartPart.ChartSpace.Descendants<Values>().ToList();
        var categoryAxis = chartPart.ChartSpace.Descendants<CategoryAxisData>().ToList();

        for (int i = 0; i < this._lineSecCharts.Count; ++i)
        {
            var yourLine = this._lineSecCharts[i];

            var label = seriesLabels[i].Descendants<NumericValue>().FirstOrDefault();
            var values = seriesValues[i].Descendants<NumericValue>().ToList();
            var categories = categoryAxis[i].Descendants<NumericValue>().ToList();

            // Replaces the label of the series
            label.Text = yourLine.Label;
            // Replaces the values of the series
            for (int valIdx = 0; valIdx < values.Count(); ++valIdx)
            {
                values[valIdx].Text = yourLine.Plots[valIdx].Value.ToString();
                categories[valIdx].Text = yourLine.Plots[valIdx].Category;
            }
        }
    }

像这样有什么方法可以修改表中的数据,如果可以的话,任何人都可以为我提供解决方案,非常感谢。

4

1 回答 1

3

经过研究,我找到了答案,我可以使用 openxml 更新数据库中的表值

下面的代码(如果条件)在附加行的表和附加的图形数据之间添加

table1.Append(tableProperties1);
        table1.Append(tableGrid1);
        table1.Append(tableRow1);
        table1.Append(tableRow2);
        table1.Append(tableRow3);
        table1.Append(tableRow4);
        table1.Append(tableRow5);
        table1.Append(tableRow6);
        table1.Append(tableRow7);

 #if true    // Injects the table modification process
        TableModifier tableModifier = new TableModifier();//Create a class
        tableModifier.UpdateTable(table1);//Send the table object of which you wanted to update
 #endif
        graphicData1.Append(table1);

        graphic1.Append(graphicData1);

在 TableModifier 类中

using DocumentFormat.OpenXml.Drawing;
using DocumentFormat.OpenXml.Packaging;

public class TableModifier
{
    public TableModifier()
    {
        this.SetupDataSource();
    }

    public void UpdateTable(Table table)
    {
        var rows = table.Descendants<TableRow>().ToList();

        for (int r = 0; r < rows.Count(); ++r)
        {
            var yourRow = this._rows[r];
            var cells = rows[r].Descendants<TableCell>().ToList();

            for (int c = 0; c < cells.Count(); ++c)
            {
                var yourCell = yourRow.Cells[c];
                var text = cells[c].Descendants<Text>().FirstOrDefault();
                if (text != null)
                {
                    text.Text = yourCell.Value;
                }
            }
        }
    }

    private void SetupDataSource()
    {
        this._rows.Add(new Row()
        {
            Cells = new List<Cell>()
            {
                new Cell(){ Value = "Products" },
                new Cell(){ Value = "2010" },
                new Cell(){ Value = "2011" },
                new Cell(){ Value = "2012" },
            }
        });

        for (int i = 0; i < 6; ++i)
        {
            var productName = string.Format("Product {0}", (char)(i + 'A'));

            this._rows.Add(new Row()
            {
                Cells = new List<Cell>()
                {
                    new Cell(){ Value = productName },
                    new Cell(){ Value = "10%" },
                    new Cell(){ Value = "20%" },
                    new Cell(){ Value = "30%" },
                }
            });
        }
    }

    #region Private Data Structure

    private class Row
    {
        public List<Cell> Cells { get; set; }
    }

    private class Cell
    {
        public string Value { get; set; }
    }

    #endregion

    private List<Row> _rows = new List<Row>();
}
于 2013-03-18T05:02:30.377 回答