【转】C# Excel 图表操作(一)

本文详细介绍如何使用Excel API创建和操作图表,包括设置图表大小、指定图表类型、定义数据区域及调整图表位置等关键步骤。文章通过实例展示了不同参数设置下线型图的变化,帮助读者更好地理解和应用Excel图表API。

原文:http://www.cnblogs.com/smjack/archive/2009/02/25/1398257.html

插入图表则主要是操作ChartObject对象和Chart对象。

  Workbook wb = xla.Workbooks.Add(XlSheetType.xlWorksheet);
            Worksheet ws = (Worksheet)xla.ActiveSheet;

           // Now create the chart.
            ChartObjects charts= (ChartObjects)ws.ChartObjects(Type.Missing);

//设置图表大小。ChartObject chartObj = charts.Add(0, 0, 400, 300);Chart chart = chartObj.Chart;//设置图表数据区域。Range range = workSheet.get_Range("A1", "E10");chart.ChartWizard(range, XlChartType.xl3DColumn,miss,XlRowCol.xlColumns, 1, 1, true, "标题", "X轴标题", "Y轴标题", miss);//将图表移到数据区域之下。chartObj.Left = Convert.ToDouble(range.Left);chartObj.Top = Convert.ToDouble(range.Top) + Convert.ToDouble(range.Height);

其中设置图表区域比较关键,区域中包含了标题行。ChartWizard的第二个参数指明了图表的类型,第四个参数指明了以行还是列的值作为一个数据系列,第五个参数和第六个参数则指明分别作为横轴坐标和系列名称的单元格。

以Line类型图表为例,数据如下:

01234
12345
23456
34567
45678
56789
678910
7891011
89101112
910111213

那么根据第四个参数的不同会有两种不同图表:

chart.ChartWizard(range, XlChartType.xlLine,miss,XlRowCol.xlRows, 1, 1, true, "标题", "X轴标题", "Y轴标题", miss);

.Net创建Excel文件(插入数据、修改格式、生成图表)的方法

在PlotBy Row的时候,会以一行的数据为一个数据系列画一条线,并把第每行的一列值作为这一条线的标题,而把第一行的每一列作为该线的横坐标。

chart.ChartWizard(range, XlChartType.xlLine,miss,XlRowCol.xlColumns, 1, 1, true, "标题", "X轴标题", "Y轴标题", miss);

.Net创建Excel文件(插入数据、修改格式、生成图表)的方法 

在PlotBy Column的时候,会以一列的数据为一个数据系列画一条线,并把第每列的一行值作为这一条线的标题,而把第一列的每一行作为该线的横坐标。

这两种模式相同点就在于,它们都是以坐标格内的值作为纵坐标的。这里需要注意的是,如果第五和第六个参数改为2,并不是取行的第二列或列的第二行作为标题,而是取前两行或前两列,比如:

chart.ChartWizard(range, XlChartType.xlLine,miss,XlRowCol.xlColumns, 2, 0, true, "标题", "X轴标题", "Y轴标题", miss);

.Net创建Excel文件(插入数据、修改格式、生成图表)的方法

由于系列标题设置为0,所以使用了默认的“系列X”作为标题,而横坐标则取了每列的前两行,所以共有三条线,每条线上10个点。

 

转载于:https://www.cnblogs.com/jiangj/archive/2010/09/06/1819018.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值