本博客所有文章分类的总目录:http://www.cnblogs.com/asxinyu/p/4288836.html

.NET读写Excel工具Spire.Xls使用文章目录:http://www.cnblogs.com/asxinyu/p/4374032.html

  前一篇文章:“.NET读写Excel工具Spire.Xls使用(4)对数据操作与控制”给大家介绍了Spire.XLS对数据的控制相关功能,这一篇给大家介绍Spire.XLS最大的亮点所在,C#控制Excel生成图表。将介绍C#生成不同类型图表的方法,并介绍Excel图表的相关操作,如调整大小,保存图片等操作的方法。

1.Excel中的图表

  我们生活的这个世界是丰富多彩的,几乎所有的知识都来自于视觉。也许无法记住一连串的数字,以及它们之间的关系和趋势。但是可以很轻松地记住一幅图画或者一个曲线。因此由于使用图表,会使得用Excel编制的工作表更易于理解和交流。Excel具有许多高级的制图功能,同时使用起来也非常简便。在本章中,我们将学习到建立一张简单的图表,再进行修饰,使图表更加精致,以及如何为图形加上背景、图注、正文等等。Excel中图表是指将工作表中的数据用图形表示出来。例如:将各地区每周的销售用柱形图显示出来,见图8-1的显示。图表可以使数据更加有趣、吸引人、易于阅读和评价。它们也可以帮助我们分析和比较数据[1]。如下图所示的图表,看数据多累,看图表就一目了然。。。

2.C#创建Excel图表方法

2.1 Spire.Xls的图表类

  在Spire.Xls组件中,生成图表已经非常简化了。只需要一个核心的Chart类,就可以增加图表并进行辅助的一些设置。Spire.Xls定义支持的图表类型,在枚举ExcelChartType类型中。目前一共有74种类型,可以使用对象浏览器大概看一下:  

  在实际的使用过程中,添加Excel图表主要有以下几个过程:

1.给指定的Sheet添加需要的Excel图表的类型;

2.设置图表所需要的数据范围;

3.设置图表的位置以及标题;

4.设置系列图表以及坐标轴的值。

  下面将使用C#和Spire.Xls组件做一个生成饼状图和折线图的例子,看看基本的使用过程。

2.2 生成饼状图

  在工作中如果遇到需要计算总费用或金额的各个部分构成比例的情况,一般都是通过各个部分与总额相除来计算,而且这种比例表示方法很抽象,我们可以使用一种饼状图表工具,能够直接以图形的方式直接显示各个组成部分所占比例,在Excel中可以很方便的制作饼状图表。Spire.Xls中饼状图类型是ExcelChartType类中的Pie和Pie3D,为了效果很好看,我们可以使用3D的类型。

 1 //创建饼状图表
 2 Chart chart = sheet.Charts.Add(ExcelChartType.Pie);
 3 //设置图表的数据范围,使用的也是和前面单元格获取的Range对象
 4 chart.DataRange = sheet.Range["B2:B5"];
 5 chart.SeriesDataFromRange = false;
 6
 7 //设置图表的位置
 8 chart.LeftColumn = 1;//图表左边列
 9 chart.TopRow = 6;//图表上部的行
10 chart.RightColumn = 6;//图表右边列
11 chart.BottomRow = 18;//图表底部行
12
13 //图表标题
14 chart.ChartTitle = "饼形图例子";
15 //设置字体
16 chart.ChartTitleArea.IsBold = true;
17 chart.ChartTitleArea.Size = 12;
18
19 //初始化图例
20 Spire.Xls.Charts.ChartSerie cs = chart.Series[0];
21 //图表的标签目录数据
22 cs.CategoryLabels = sheet.Range["A2:A5"];
23 //图表的主要值,也就是饼状图的数据
24 cs.Values = sheet.Range["B2:B5"];

如下所示的效果:

2.3 生成折线图

  线图是用直线段将各数据点连接起来而组成的图形,以折线方式显示数据的变化趋势。折线图可以显示随时间(根据常用比例设置)而变化的连续数据,因此非常适用于显示在相等时间间隔下数据的趋势。在折线图中,类别数据沿水平轴均匀分布,所有值数据沿垂直轴均匀分布。在折线图中,数据是递增还是递减、增减的速率、增减的规律(周期性、螺旋性等)、峰值等特征都可以清晰地反映出来。所以,折线图常用来分析数据随时间的变化趋势,也可用来分析多组数据随时间变化的相互作用和相互影响。

  使用Spire.Xls绘制折线图过程和上面的类型。但如果图例较多,就是设置稍微复杂一点。看一个例子:

 1 //给Sheet对象添加一个图表对象,可以直接添加类型,也可以单独用ChartType赋值来添加
 2 Chart chart = sheet.Charts.Add();
 3 chart.ChartType = ExcelChartType.Line3D;
 4
 5 //设置图表的数据范围
 6 chart.DataRange = sheet.Range["A1:E5"];
 7
 8 //设置图表的保存位置,这个基本都差不多
 9 chart.LeftColumn = 1;
10 chart.TopRow = 6;
11 chart.RightColumn = 7;
12 chart.BottomRow = 22;
13
14 //图表标题
15 chart.ChartTitle = "折线图例子";
16 //设置字体加粗和大小
17 chart.ChartTitleArea.IsBold = true;
18 chart.ChartTitleArea.Size = 12;
19 //设置横坐标的标题
20 chart.PrimaryCategoryAxis.Title = "月份";
21 chart.PrimaryCategoryAxis.Font.IsBold = true;
22 chart.PrimaryCategoryAxis.TitleArea.IsBold = true;
23 //设置纵坐标,也就是值 的标题
24 chart.PrimaryValueAxis.Title = "销售额";
25 chart.PrimaryValueAxis.HasMajorGridLines = false;
26 chart.PrimaryValueAxis.TitleArea.TextRotationAngle = 90;
27 chart.PrimaryValueAxis.MinValue = 1000;
28 chart.PrimaryValueAxis.TitleArea.IsBold = true;
29 //循环绘制不同国家的销售额折线图,有多个系列
30 foreach (Spire.Xls.Charts.ChartSerie cs in chart.Series)
31 {
32     cs.Format.Options.IsVaryColor = true;
33     cs.DataPoints.DefaultDataPoint.DataLabels.HasValue = true;
34 }

实际的效果和原始数据如下图所示:

  其他图表的过程都类似,可以在帮助文档中找到相关例子。

3.C#设置Excel图表

3.1 将图表保存为图片

  Excel生成的图表是可以保存为图片的。在Spire.XLS中,这些操作已经变得非常简单。首先获取Workbook对象的SaveChartAsImage方法获取指定sheet中的所有图表。然后循环将图片对象依次保存即可,下面是主要代码:

1 Workbook workbook = new Workbook();
2 workbook.LoadFromFile("chart.xlsx", ExcelVersion.Version2010);
3 Worksheet sheet=workbook.Worksheets[0];
4 Image[] imgs = workbook.SaveChartAsImage(sheet);
5 for (int i = 0; i < imgs.Length; i++)
6 {
7     imgs[i].Save(string.Format("img-{0}.png", i), ImageFormat.Png);
8 }

3.2 位置调整

  Excel中的图表的位置已经在前面介绍过,还有一个可以调整大小的功能。使用Width和Height方法直接设置大小即可。

1 chart.Width = 400;
2 chart.Height = 250;

  上面就是一些常规的操作和使用,总的来说还是比较简单,如果需要比较细致的,可以查看API文档,根据方法来所要的功能来找,实现起来也会很容易的。

[1].http://baike.haosou.com/doc/5449555-5687924.html

【原创】.NET读写Excel工具Spire.Xls使用(5)重量级的Excel图表功能相关推荐

  1. 【原创】.NET读写Excel工具Spire.Xls使用(4)对数据操作与控制

                  本博客所有文章分类的总目录:http://www.cnblogs.com/asxinyu/p/4288836.html .NET读写Excel工具Spire.Xls使用文章 ...

  2. .NET读写Excel工具Spire.Xls使用(1)入门介绍

    原文:[原创].NET读写Excel工具Spire.Xls使用(1)入门介绍 在.NET平台,操作Excel文件是一个非常常用的需求,目前比较常规的方法有以下几种: 1.Office Com组件的方式 ...

  3. NPOI写Excel,Spire.XLS for.NET组件转换Excel为PDF

    首先要引用NPOI动态库和Microsoft.Office.Interop.excel.dll (Microsoft.Office.Interop.excel.dll  最好使用使用NuGet下载 , ...

  4. 【目录】C#操作Excel组件Spire.XLS系列文章目录

    本博客所有文章分类的总目录链接:http://www.cnblogs.com/asxinyu/p/4288836.html 1.C#操作Excel组件Spire.XLS文章目录 1.[原创].NET读 ...

  5. .NET Excel 组件Spire.XLS for .NET v9.7发布上线!支持将外部字体文件应用于图表!

    Spire.XLS for .NET是一款专业的 .NET Excel 组件, 它可以用在各种 .NET 框架中,包括 .NET Core.ASP.NET 和 Windows Forms 等相关的 . ...

  6. C#组件系列——又一款Excel处理神器Spire.XLS,你值得拥有

    阅读目录 一.组件介绍 二.组件安装使用 1.官方下载安装 2.Nuget安装 三.组件功能介绍 1.Excel转PDF 2.Excel生成图表 3.其他功能介绍 四.总结 正文 前言:最近项目里面有 ...

  7. Spire.XLS:一款Excel处理神器

    正文 前言:最近项目里面有一些对Excel操作的需求,博主想都没想,NPOI呗,简单.开源.免费,大家都喜欢!确实,对于一些简单的Excel导入.导出.合并单元格等,它都没啥太大的问题,但是这次的需求 ...

  8. C#组件系列——又一款Excel处理神器Spire.XLS(一)

    阅读目录 一.组件介绍 二.组件安装使用 1.官方下载安装 2.Nuget安装 三.组件功能介绍 1.Excel转PDF 2.Excel生成图表 3.其他功能介绍 四.总结 正文 前言:最近项目里面有 ...

  9. Spire.XLS 教程:从C#的Excel形状中提取文本和图像

    2019独角兽企业重金招聘Python工程师标准>>> 一个excel形状可以用文字或图像填充,有时我们需要读取形状中的文字和图像信息. 在本文中,我们将介绍如何使用Spire.XL ...

  10. Excel控件Spire.XLS 教程:C#中激活工作表

    Spire.XLS 是一个专业的Excel控件,有 .NET.WPF和Silverlight 版本,通过Spire.XLS无需安装微软Excel,也能拥有Excel的全套功能,本文介绍了如何通过Spi ...

最新文章

  1. SQL数据库学习之路(九)
  2. Keras入门(一)搭建深度神经网络(DNN)解决多分类问题
  3. ASP.NET MVC 向浏览器发送文件以提供文件下载功能
  4. C# 委托 (一)—— 委托、 泛型委托与Lambda表达式
  5. request和response对象如何解决中文乱码问题?
  6. 李彦宏、王海峰等成为工程院院士候选人选
  7. 二维数组转datatable的代码
  8. error: expected '=', ',', ';', 'asm' or '__attribute__' before '{' token
  9. shell脚本解析5----循环语句
  10. bay——RAC_ASM ORA-15001 diskgroup DATA does not exist or is not mounted.docx
  11. SSL/TLS协议详解(上):密码套件,哈希,加密,密钥交换算法
  12. NLP(四十二)人物关系分类的再次尝试
  13. 视频运动放大一:欧拉视频放大,《Eulerian video magnification for revealing subtle changes in the world》
  14. 关于android某些手机java.lang.UnsatisfiedLinkError: No implementation found for ......的问题
  15. 因测试和登录软件微信被封,淘客必须注意,微信封号原则是什么?
  16. 手机连接电脑热点 显示 连接超时,已解决
  17. PLSQL存储过程定时作业(DBMS_JOB)
  18. 服务器信号满格但上不了网,新版tplink路由器wifi信号满格上不了网怎么办?
  19. PC端和移动端微信加入群聊的测试点分析
  20. 2019最新迅为-i.MX6Q开发板资料目录

热门文章

  1. 9个实用PHP函数和功能
  2. 题目:将一个正整数分解质因数
  3. 原生Hadoop集群搭建过程记录
  4. java selenium sleep_【转】java-selenium三种等待方式
  5. Call for Speaker!Flink Forward 全球在线会议议题征集 ing
  6. 视频播放器本地代理服务设计
  7. FFmpeg总结(十三)用ffmpeg基于nginx实现直播功能,推流拉流
  8. js使用html5,JS使用H5实现图片预览功能
  9. 大脑构造图与功能解析_EXCEL函数中Indirect才是构造函数之王,其他函数只能靠边站...
  10. c#服务器后台搭建_微信影视小程序搭建拆解:第一课,影视小程序简介,搭建影视小程序的整体流程...