Openxml format SDK 2.0 v2 的 how to 文章里提供了一个怎样插入 chart 图表的示例, 但这个 chart的数据是独立不是根据excel sheet 上data 动态生成的chart,因此, 我在此示例代码上做了一些改动,可以根据excel sheet 上的数据, 生成 chart 图片, 效果如图
data:image/s3,"s3://crabby-images/25389/2538994351f6822c24b0ae7c4ede99dde09e35be" alt=""
画图的逻辑结构为:
WorksheetPart<-DrawingsPart<-ChartPart<-ChartSpace<-Chart<-PlotArea<-BarChart<-BarChartSeries
Openxml 画excel 柱状图的数据存在在BarChartSeries, 一个BarChartSeries的实例代表一个颜色的柱子, 上图共有C1, C2两个BarChartSeries实例。
BarChartSeries 又包含三个部门:CategoryAxisData(x轴坐标), SeriesText(类型的名字, 这个也可以通过数据源取,sdk是传的固定值), Values(值, 柱状图的y轴值)。
Openxml的数据源对应的类型是DocumentFormat.OpenXml.Drawing.Charts.Formula, 如:new DocumentFormat.OpenXml.Drawing.Charts.Formula(”sheet1!$A$1:$C$4“), 这个是说取 sheet1的 A1 到C4的数据
这样我们改造sdk的代码就是 变BarChartSeries的值参, 为Openxml 的 Formula数据源
1. 生成x轴的数据源实例:
data:image/s3,"s3://crabby-images/849a8/849a86ef3296874633785479796ce82040871888" alt=""
Code
string formulaString = string.Format("{0}!${1}${2}:${3}${4}", sheetName, columnName, startx + 1, columnName, startx + rowCount -1);
CategoryAxisData cad = new CategoryAxisData();
cad.StringReference = new StringReference() { Formula = new DocumentFormat.OpenXml.Drawing.Charts.Formula(formulaString) };
2. 生成数据的数据源实例:
data:image/s3,"s3://crabby-images/849a8/849a86ef3296874633785479796ce82040871888" alt=""
Code
formulaString = string.Format("{0}!${1}${2}:${3}${4}", sheetName, columnName, startx +1, columnName, startx + rowCount-1);
DocumentFormat.OpenXml.Drawing.Charts.Values v = new DocumentFormat.OpenXml.Drawing.Charts.Values();
v.NumberReference = new NumberReference() { Formula = new DocumentFormat.OpenXml.Drawing.Charts.Formula(formulaString) };
这个数据源取得数据需要把保证cell的datatype 是"Number";因此在写数据时要用如下方法
Cell cell = InsertCellInWorksheet(name, Convert.ToUInt32(j + startx), worksheetPart);
cell.CellValue = new CellValue(index.ToString());
cell.DataType = new EnumValue<CellValues>(CellValues.Number);
worksheetPart.Worksheet.Save();
3. 生成分类柱的名字:
data:image/s3,"s3://crabby-images/849a8/849a86ef3296874633785479796ce82040871888" alt=""
Code
formulaString = string.Format("{0}!${1}${2}", sheetName, columnName, startx);
SeriesText st = new SeriesText();
st.StringReference = new StringReference() { Formula = new DocumentFormat.OpenXml.Drawing.Charts.Formula(formulaString) };
4. 生成柱状图的一个分类的实例:
data:image/s3,"s3://crabby-images/849a8/849a86ef3296874633785479796ce82040871888" alt=""
Code
BarChartSeries barChartSeries = barChart.AppendChild<BarChartSeries>(new BarChartSeries(new Index() { Val = new UInt32Value(i) },
new Order() { Val = new UInt32Value(i) }, st, v));
if (sIndex == 1)
barChartSeries.AppendChild(cad);
这里startx表示excel行索引, starty表示excel的列索引
改造SDK how to 方法的完整代码:
data:image/s3,"s3://crabby-images/849a8/849a86ef3296874633785479796ce82040871888" alt=""
Code
1data:image/s3,"s3://crabby-images/9ed40/9ed401c13ef0ca53ee83c3ffe3144daad9d9621b" alt=""
/**//// <summary>
2
/// draw the 2D bar chart
3
/// index start from 1
4
/// </summary>
5
/// <param name="startx">index start from 1 for row</param>
6
/// <param name="starty">index start from 1 for column</param>
7
/// <param name="columnCount"></param>
8
/// <param name="rowCount"></param>
9
public void InsertChartInSpreadsheet(int startx, int starty, int columnCount, int rowCount)
10data:image/s3,"s3://crabby-images/9ed40/9ed401c13ef0ca53ee83c3ffe3144daad9d9621b" alt=""
{
11
WorksheetPart worksheetPart = CurrentWorksheetPart;
12data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
13data:image/s3,"s3://crabby-images/d971a/d971a4cc90bc374b8da297f155149f2530d697e9" alt=""
SDK How to example code#region SDK How to example code
14
// Add a new drawing to the worksheet.
15
DrawingsPart drawingsPart = worksheetPart.AddNewPart<DrawingsPart>();
16data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
worksheetPart.Worksheet.Append(new DocumentFormat.OpenXml.Spreadsheet.Drawing()
{ Id = worksheetPart.GetIdOfPart(drawingsPart) });
17
worksheetPart.Worksheet.Save();
18data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
19
// Add a new chart and set the chart language to English-US.
20
ChartPart chartPart = drawingsPart.AddNewPart<ChartPart>();
21
chartPart.ChartSpace = new ChartSpace();
22data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
chartPart.ChartSpace.Append(new EditingLanguage()
{ Val = new StringValue("en-US") });
23
DocumentFormat.OpenXml.Drawing.Charts.Chart chart = chartPart.ChartSpace.AppendChild<DocumentFormat.OpenXml.Drawing.Charts.Chart>(
24
new DocumentFormat.OpenXml.Drawing.Charts.Chart());
25data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
26
// Create a new clustered column chart.
27
PlotArea plotArea = chart.AppendChild<PlotArea>(new PlotArea());
28
Layout layout = plotArea.AppendChild<Layout>(new Layout());
29data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
BarChart barChart = plotArea.AppendChild<BarChart>(new BarChart(new BarDirection()
{ Val = new EnumValue<BarDirectionValues>(BarDirectionValues.Column) },
30data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
new BarGrouping()
{ Val = new EnumValue<BarGroupingValues>(BarGroupingValues.Clustered) }));
31
#endregion
32data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
33
string sheetName = GetCurrentSheetName();
34
string columnName = GetColumnName(starty - 1);
35
string formulaString = string.Format("{0}!${1}${2}:${3}${4}", sheetName, columnName, startx + 1, columnName, startx + rowCount - 1);
36
CategoryAxisData cad = new CategoryAxisData();
37data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
cad.StringReference = new StringReference()
{ Formula = new DocumentFormat.OpenXml.Drawing.Charts.Formula(formulaString) };
38data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
39
uint i = 0;
40
for (int sIndex = 1; sIndex < columnCount; sIndex++)
41data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
42
columnName = GetColumnName(starty + sIndex - 1);
43
formulaString = string.Format("{0}!${1}${2}", sheetName, columnName, startx);
44
SeriesText st = new SeriesText();
45data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
st.StringReference = new StringReference()
{ Formula = new DocumentFormat.OpenXml.Drawing.Charts.Formula(formulaString) };
46data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
47
formulaString = string.Format("{0}!${1}${2}:${3}${4}", sheetName, columnName, startx + 1, columnName, startx + rowCount - 1);
48
DocumentFormat.OpenXml.Drawing.Charts.Values v = new DocumentFormat.OpenXml.Drawing.Charts.Values();
49data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
v.NumberReference = new NumberReference()
{ Formula = new DocumentFormat.OpenXml.Drawing.Charts.Formula(formulaString) };
50data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
51data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
BarChartSeries barChartSeries = barChart.AppendChild<BarChartSeries>(new BarChartSeries(new Index()
{ Val = new UInt32Value(i) },
52data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
new Order()
{ Val = new UInt32Value(i) }, st, v));
53
if (sIndex == 1)
54
barChartSeries.AppendChild(cad);
55
i++;
56
}
57data:image/s3,"s3://crabby-images/d971a/d971a4cc90bc374b8da297f155149f2530d697e9" alt=""
SDK how to example Code#region SDK how to example Code
58data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
59data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
barChart.Append(new AxisId()
{ Val = new UInt32Value(48650112u) });
60data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
barChart.Append(new AxisId()
{ Val = new UInt32Value(48672768u) });
61data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
62
// Add the Category Axis.
63data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
CategoryAxis catAx = plotArea.AppendChild<CategoryAxis>(new CategoryAxis(new AxisId()
{ Val = new UInt32Value(48650112u) },
64
new Scaling(new Orientation()
65data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
66
Val = new EnumValue<DocumentFormat.OpenXml.Drawing.Charts.OrientationValues>(
67
DocumentFormat.OpenXml.Drawing.Charts.OrientationValues.MinMax)
68
}),
69data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
new AxisPosition()
{ Val = new EnumValue<AxisPositionValues>(AxisPositionValues.Bottom) },
70data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
new TickLabelPosition()
{ Val = new EnumValue<TickLabelPositionValues>(TickLabelPositionValues.NextTo) },
71data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
new CrossingAxis()
{ Val = new UInt32Value(48672768U) },
72data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
new Crosses()
{ Val = new EnumValue<CrossesValues>(CrossesValues.AutoZero) },
73data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
new AutoLabeled()
{ Val = new BooleanValue(true) },
74data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
new LabelAlignment()
{ Val = new EnumValue<LabelAlignmentValues>(LabelAlignmentValues.Center) },
75data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
new LabelOffset()
{ Val = new UInt16Value((ushort)100) }));
76data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
77
// Add the Value Axis.
78data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
ValueAxis valAx = plotArea.AppendChild<ValueAxis>(new ValueAxis(new AxisId()
{ Val = new UInt32Value(48672768u) },
79
new Scaling(new Orientation()
80data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
81
Val = new EnumValue<DocumentFormat.OpenXml.Drawing.Charts.OrientationValues>(
82
DocumentFormat.OpenXml.Drawing.Charts.OrientationValues.MinMax)
83
}),
84data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
new AxisPosition()
{ Val = new EnumValue<AxisPositionValues>(AxisPositionValues.Left) },
85
new MajorGridlines(),
86data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
new DocumentFormat.OpenXml.Drawing.Charts.NumberFormat()
{ FormatCode = new StringValue("General"), SourceLinked = new BooleanValue(true) },
87data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
new TickLabelPosition()
{ Val = new EnumValue<TickLabelPositionValues>(TickLabelPositionValues.NextTo) },
88data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
new CrossingAxis()
{ Val = new UInt32Value(48650112U) },
89data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
new Crosses()
{ Val = new EnumValue<CrossesValues>(CrossesValues.AutoZero) },
90data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
new CrossBetween()
{ Val = new EnumValue<CrossBetweenValues>(CrossBetweenValues.Between) }));
91data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
92
// Add the chart Legend.
93data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
Legend legend = chart.AppendChild<Legend>(new Legend(new LegendPosition()
{ Val = new EnumValue<LegendPositionValues>(LegendPositionValues.Right) },
94
new Layout()));
95data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
96data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
chart.Append(new PlotVisibleOnly()
{ Val = new BooleanValue(true) });
97data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
98
// Save the chart part.
99
chartPart.ChartSpace.Save();
100data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
101
// Position the chart on the worksheet using a TwoCellAnchor object.
102
drawingsPart.WorksheetDrawing = new WorksheetDrawing();
103
TwoCellAnchor twoCellAnchor = drawingsPart.WorksheetDrawing.AppendChild<TwoCellAnchor>(new TwoCellAnchor());
104
twoCellAnchor.Append(new FromMarker(new ColumnId("9"),
105
new ColumnOffset("581025"),
106
new RowId("17"),
107
new RowOffset("114300")));
108
twoCellAnchor.Append(new ToMarker(new ColumnId("17"),
109
new ColumnOffset("276225"),
110
new RowId("32"),
111
new RowOffset("0")));
112data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
113
// Append a GraphicFrame to the TwoCellAnchor object.
114
DocumentFormat.OpenXml.Drawing.Spreadsheet.GraphicFrame graphicFrame =
115
twoCellAnchor.AppendChild<DocumentFormat.OpenXml.Drawing.Spreadsheet.GraphicFrame>(
116
new DocumentFormat.OpenXml.Drawing.Spreadsheet.GraphicFrame());
117
graphicFrame.Macro = "";
118data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
119
graphicFrame.Append(new DocumentFormat.OpenXml.Drawing.Spreadsheet.NonVisualGraphicFrameProperties(
120data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
new DocumentFormat.OpenXml.Drawing.Spreadsheet.NonVisualDrawingProperties()
{ Id = new UInt32Value(2u), Name = "Chart 1" },
121
new DocumentFormat.OpenXml.Drawing.Spreadsheet.NonVisualGraphicFrameDrawingProperties()));
122data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
123data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
graphicFrame.Append(new Transform(new Offset()
{ X = 0L, Y = 0L },
124data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
new Extents()
{ Cx = 0L, Cy = 0L }));
125data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
126data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
graphicFrame.Append(new Graphic(new GraphicData(new ChartReference()
{ Id = drawingsPart.GetIdOfPart(chartPart) })
{ Uri = "http://schemas.openxmlformats.org/drawingml/2006/chart" }));
127data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
128
twoCellAnchor.Append(new ClientData());
129data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
130
// Save the WorksheetDrawing object.
131
drawingsPart.WorksheetDrawing.Save();
132data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
133
#endregion
134
}
获取当前sheet name的方法:
data:image/s3,"s3://crabby-images/849a8/849a86ef3296874633785479796ce82040871888" alt=""
Code
private string GetCurrentSheetName()
{
string name = "";
WorkbookPart workbookPart = spreadSheet.WorkbookPart;
string relationshipId = workbookPart.GetIdOfPart(CurrentWorksheetPart);
Sheets sheets = workbookPart.Workbook.GetFirstChild<Sheets>();
foreach (Sheet item in sheets)
{
if (item.Id == relationshipId)
{
name = item.Name;
break;
}
}
return name;
}
怎样生成excel 并写数据请参看 http://www.cnblogs.com/skyfei/archive/2009/06/12/Openxml.html