我对 C# 中的 Excel 自动化完全陌生
实际上,我在 C# .net 中遇到了一些用于生成 Excel 的 API,例如 vincent 的 CLOSED XML、EEPLUS 和电子表格、Microsoft 的 Open XML、Microsoft 的 Interop excel
根据我的研究
CLOSED XML——不支持图表
EEPLUS - 支持图表
Spread light - 非常易于使用,还支持图表
开放 XML - 复杂难于工作
我完全同意 Spread light light was good API,但我无法找到如何在图表中添加标签的解决方案
我希望堆栈溢出中的任何人都遇到同样的问题。
我需要在图表内添加标签(如文本),例如图表中的公司。
请让我知道如何通过这个免费 API 找到解决方案
谢谢
兰吉斯
您可以通过 Epplus 添加标题,但定位需要 XML 编辑:
[TestMethod]
public void Chart_Manual_Title_Test()
{
//http://stackoverflow.com/questions/37304860/how-to-add-to-text-label-for-excel-charts-using-open-xml-or-epplus
//Throw in some data
var datatable = new DataTable("tblData");
datatable.Columns.AddRange(new[] { new DataColumn("Col1", typeof(int)), new DataColumn("Col2", typeof(int)), new DataColumn("Col3", typeof(object)) });
for (var i = 0; i < 10; i++)
{
var row = datatable.NewRow();
row[0] = i;
row[1] = i * 10;
row[2] = Path.GetRandomFileName();
datatable.Rows.Add(row);
}
//Create a test file
var fileInfo = new FileInfo(@"c:\temp\Chart_Manual_Title_Test.xlsx");
if (fileInfo.Exists)
fileInfo.Delete();
using (var pck = new ExcelPackage(fileInfo))
{
var workbook = pck.Workbook;
var worksheet = workbook.Worksheets.Add("Sheet1");
worksheet.Cells.LoadFromDataTable(datatable, true);
var chart = worksheet.Drawings.AddChart("chart test", eChartType.XYScatter);
var series = chart.Series.Add(worksheet.Cells["B2:B11"], worksheet.Cells["A2:A11"]);
chart.Title.Text = "XYZ Corp";
//Add custom layout
var chartXml = chart.ChartXml;
var nsm = new XmlNamespaceManager(chartXml.NameTable);
var nsuri = chartXml.DocumentElement.NamespaceURI;
nsm.AddNamespace("c", nsuri);
nsm.AddNamespace("a", "http://schemas.openxmlformats.org/drawingml/2006/main");
//Set the title overlay
var overlayNode = chartXml.SelectSingleNode("c:chartSpace/c:chart/c:title/c:overlay", nsm);
overlayNode.Attributes["val"].Value = "1";
//Set the font size
var defRPrNode = chartXml.SelectSingleNode("c:chartSpace/c:chart/c:title/c:tx/c:rich/a:p/a:pPr/a:defRPr", nsm);
defRPrNode.Attributes["sz"].Value = "1200";
//Get the title layout and add the manual section
var layoutNode = chartXml.SelectSingleNode("c:chartSpace/c:chart/c:title/c:layout", nsm);
var manualLayoutNode = chartXml.CreateElement("c:manualLayout", nsuri);
layoutNode.AppendChild(manualLayoutNode);
//Add coordinates
var xModeNode = chartXml.CreateElement("c:xMode", nsuri);
var attrib = chartXml.CreateAttribute("val");
attrib.Value = "edge";
xModeNode.Attributes.Append(attrib);
manualLayoutNode.AppendChild(xModeNode);
var yModeNode = chartXml.CreateElement("c:yMode", nsuri);
attrib = chartXml.CreateAttribute("val");
attrib.Value = "edge";
yModeNode.Attributes.Append(attrib);
manualLayoutNode.AppendChild(yModeNode);
var xNode = chartXml.CreateElement("c:x", nsuri);
attrib = chartXml.CreateAttribute("val");
attrib.Value = "0.9";
xNode.Attributes.Append(attrib);
manualLayoutNode.AppendChild(xNode);
var yNode = chartXml.CreateElement("c:y", nsuri);
attrib = chartXml.CreateAttribute("val");
attrib.Value = "0.95";
yNode.Attributes.Append(attrib);
manualLayoutNode.AppendChild(yNode);
pck.Save();
}
}
这会在输出中给出:
好吧,这有点难。正确的方法是使用
relSizeAnchor
,它可以放置在图表内并随之移动/调整大小。但你必须从头开始(或者最多是另一个库)。如果您在 Excel 中激活图表并执行“插入”>“文本框”以查看其外观。
另一种选择是通过使用未使用的标题(例如轴标题)来伪造它,并像我移动图表标题一样移动它。
但最简单的选择是简单地添加一个形状。缺点是如果您移动图表,它不会随之移动:
var tb1 = worksheet.Drawings.AddShape("tb1", eShapeStyle.Rect);
tb1.Text = "ABC Company";
tb1.SetPosition(1, 0, 2, 0);
tb1.SetSize(200, 20);
tb1.Font.Color = Color.Black;
tb1.TextAlignment = eTextAlignment.Center;
tb1.Fill.Color = Color.LightYellow;
tb1.Fill.Style = eFillStyle.SolidFill;
tb1.Border.Fill.Color = Color.Red;
将其作为与上面结合时的输出:
Essential XlsIO可以向Excel图表添加文本框。
//Accessing the chart of the worksheet
IChartShape shape = workbook.Worksheets[0].Charts[0];
//Adding textbox to chart shape
shape.TextBoxes.AddTextBox(1,1, 100,200);
//Setting position for textbox
shape.TextBoxes[0].Top = 900;
shape.TextBoxes[0].Left = 750;
//Adding text to textbox
shape.TextBoxes[0].Text = "New textbox";
如果您符合资格(收入低于 100 万美元),可以通过社区许可证计划免费使用整套控件(也可用于商业应用程序)。社区许可证是完整的产品,没有任何限制或水印。
注:我为 Syncfusion 工作。
如果图表已存在于您的模板中并且您只是添加数据,那么您可以从页面上的单元格读取框中的内容。然后,在 C# 中,您只需写入单元格即可。这使您可以在 Excel 中执行所需的任何格式设置或定位。