C# 创建EXCEL图表并保存为图片

简介: 数据表格能够清晰的呈现数据信息,但是我们对于一些繁杂多变的数据想要很直观的看到数据变化走势或者数据的占比时,数据图表会更具代表性,并且在呈现数据信息上也更形象,也能获取更多纯数字信息所不能直接展现的信息。
+关注继续查看

数据表格能够清晰的呈现数据信息,但是我们对于一些繁杂多变的数据想要很直观的看到数据变化走势或者数据的占比时,数据图表会更具代表性,并且在呈现数据信息上也更形象,也能获取更多纯数字信息所不能直接展现的信息。在下面的代码中,将向您展示如何通过使用免费的Free Spire XLS for .NET组件来实现。

原数据表格:

C#

 1 using Spire.Xls;
 2 using System.Drawing;
 3 using System.Drawing.Imaging;
 4 
 5 namespace CreateChart_XLS
 6 {
 7     class Program
 8     {
 9         static void Main(string[] args)
10         {
11             //创建一个Workbook类实例,加载Excel文档
12             Workbook workbook = new Workbook();
13             workbook.LoadFromFile(@"C:\Users\Administrator\Desktop\Sample.xlsx");
14 
15             //获取第一个工作表
16             Worksheet sheet = workbook.Worksheets[0];
17 
18             //设置工作表的名称
19             sheet.Name = "柱状图";
20             sheet.GridLinesVisible = false;
21 
22             //创建柱状图
23             Chart chart = sheet.Charts.Add(ExcelChartType.ColumnClustered);
24 
25             //指定用于生成图表的数据区域
26             chart.DataRange = sheet.Range["A2:G6"];
27             chart.SeriesDataFromRange = false;
28 
29             //指定图表所在的位置
30             chart.LeftColumn = 1;
31             chart.TopRow = 9;
32             chart.RightColumn = 12;
33             chart.BottomRow = 26;
34 
35             //设置图表的名称及字体格式
36             chart.ChartTitle = "上半年产品销售情况(单位:万美元)";
37             chart.ChartTitleArea.IsBold = true;
38             chart.ChartTitleArea.Size = 12;
39 
40             //设置X轴坐标名称及字体格式
41             chart.PrimaryCategoryAxis.Title = "产品类别";
42             chart.PrimaryCategoryAxis.Font.IsBold = true;
43             chart.PrimaryCategoryAxis.TitleArea.IsBold = false;
44          
45             //设置Y轴坐标名称及字体格式
46             chart.PrimaryValueAxis.Title = "销售额";            
47             chart.PrimaryValueAxis.HasMajorGridLines = false;
48             chart.PrimaryValueAxis.TitleArea.TextRotationAngle = 90;
49             chart.PrimaryValueAxis.MinValue = 0.5;
50             chart.PrimaryValueAxis.TitleArea.IsBold = false;
51 
52             //设置图例的位置
53             chart.Legend.Position = LegendPositionType.Right;
54 
55              //保存文档
56             workbook.SaveToFile("ColumnChart.xlsx", ExcelVersion.Version2013);
57 
58 
59              //加载生成图表后的Excel文档
60             workbook.LoadFromFile("ColumnChart.xlsx");
61 
62             //遍历工作簿,诊断是否包含图表
63             Image[] images = workbook.SaveChartAsImage(sheet);
64 
65              for (int i = 0; i < images.Length; i++)
66               {
67                  //将图表保存为图片
68                   images[i].Save(string.Format("img-{0}.png", i), ImageFormat.Png);
69                }
70         }
71     }
72 }

 

生成的图表文件及图片如下图所示:

组件获取地址:https://www.e-iceblue.cn/Downloads/Free-Spire-XLS-NET.html

以上是对Excel数据表格生成并转化为图表的全部操作,希望对你有所帮助,欢迎转载(转载请注明出处)

感谢浏览!

目录
相关文章
|
1月前
|
数据可视化
设置Excel区域边
设置Excel区域边
7 2
导出图片和数据到Excel
导出图片和数据到Excel
|
4月前
|
JSON JavaScript 数据格式
echarts读取excle转为json格式显示图表同步加载数据的方法(1)
echarts读取excle转为json格式显示图表同步加载数据的方法(1)
75 0
|
11月前
|
Android开发
安卓中显示表格并将表格数据以excel格式导出
安卓中显示表格并将表格数据以excel格式导出
298 0
|
移动开发 前端开发 Unix
复制excel数据到网页表格上
在前端开发过程中,有的时候我们会希望可以直接将excel上的数据复制粘贴到页面上的表格中,所以也就有了这一篇博客。
441 0
复制excel数据到网页表格上
|
前端开发
POI复制Excel模板并填充数据
我们最近需要对系统加一个报表导出的功能,可以通过POI直接导出,导出后的excel文件需要支持在office里面修改数据后图表也会自动变换。方法一可以使用jfreechart+poi,但是这种方法生成的图表是一张图片,不能在office中自动修改;第二种方法是poi调用 office的宏,它需要调用自定义的.dll 文件,也需要在windows环境中,所以不适用。
6228 0
|
移动开发 C#
C# 添加、修改以及删除Excel迷你图表的方法
Excel表格中的迷你图表能够直观地向我们展示出数据的变化趋势。本文将介绍C#如何实现为表格数据生成迷你图表,以及修改和删除迷你图表的方法。下面将详细讲述。 所用组件工具:Spire.XLS for .
1198 0
相关产品
云迁移中心
推荐文章
更多