一起谈.NET技术,.Net创建Excel文件(插入数据、修改格式、生成图表)的方法

简介: 1.添加Excel引用  可以在.Net选项卡下添加Microsoft.Office.Interop.Excel引用,或在COM下添加Microsoft Excel 12.0 Object Library。

1.添加Excel引用

  可以在.Net选项卡下添加Microsoft.Office.Interop.Excel引用,或在COM下添加Microsoft Excel 12.0 Object Library。它们都会生成Microsoft.Office.Interop.Excel.dll。

2.创建Excel。

  有两种方法创建一个Excel Workbook实例。

  1.需要一个模板文件,使用Open方法,参数较多:

 
 
1 object miss = Missing.Value;
2 Application excelApp = new Application();
3 excelApp.Workbooks.Open(TemplateName, miss, true , miss, miss, miss, miss, miss, miss, miss, miss, miss, miss, miss, miss);

  其中Open方法的第一个和第三个参数是模板名称(路径)和是否只读。其余参数一般不需要设置。这里将原文件设为只读,因为不会对模板文件进行修改。

  2.不需要模板文件,使用Add方法,只需要一个参数:

 
 
1 object miss = Missing.Value;
2 Application excelApp = new Application();
3 excelApp.Workbooks.Add(miss);

3.向Excel中插入数据表

  插入数据表的方法比较简单,使用之前生成的WorkBook中的WorkSheet,向里面添加二维数据,需要调用WorkSheet接口的get_Range方法获取插入区域,然后通过Value2(忽略格式)赋值。

 
 
1 Worksheet workSheet = (Worksheet)excelApp.Worksheets[ 2 ];
2   int rowCount = 20 ;
3   int colCount = 5 ;
4   object [,] dataArray = new object [rowCount, colCount];
5 Random rand = new Random(DateTime.Now.Millisecond);
6   for ( int i = 0 ; i < rowCount ;i ++ )
7 {
8 for ( int j = 0 ;j < colCount;j ++ )
9 {
10 dataArray[i, j] = i + j;
11 }
12 }
13 workSheet.get_Range(workSheet.Cells[ 1 , 1 ], workSheet.Cells[rowCount, colCount]).Value2 = dataArray;
14 workSheet = null;

  第一行,直接用excelApp中的Worksheet,是因为默认的Workbook是Workbooks[1],也就是直接取Workbooks[1]中的Worksheets放入Application对象的Worksheets属性中。

  倒数第二行,get_Range方法中的两个参数分别是要插入数据区域的起始和中止坐标(左上角坐标为【1,1】)。这里直接将二维数组插入表格比一点一点插入每个格子效率高些。

4.修改Excel表格样式

  设置表格样式主要是设置Range类对象的属性。和插入数据类似,通过Worksheet的get_Range方法获得需要设置样式的区域,设置相应的属性改变样式。

 
 
1 Range range = workSheet.get_Range(workSheet.Cells[ 1 , 1 ], workSheet.Cells[ 1 , colCount]);
2 range.Interior.Color = 255 ; // 设置区域背景色。
3 range.Font.Bold = true ; // 设置字体粗体。
4 range.BorderAround(XlLineStyle.xlContinuous, Microsoft.Office.Interop.Excel.XlBorderWeight.xlThick, Microsoft.Office.Interop.Excel.XlColorIndex.xlColorIndexAutomatic, 15 ); // 设置区域边框

  几乎所有可以通过图形界面对Excel格式的设置,包括公式、排序等都可以在这里设置。不过由于属性和方法没有详细的说明,所以需要一点点慢慢摸索……

5.向Excel中插入图表

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

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

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

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

0 1 2 3 4
1 2 3 4 5
2 3 4 5 6
3 4 5 6 7
4 5 6 7 8
5 6 7 8 9
6 7 8 9 10
7 8 9 10 11
8 9 10 11 12
9 10 11 12 13

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

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

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

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

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

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

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

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

6.保存Excel

  保存前,需要先刷新,使新的记录能被记下:

 
 
1 Workbook workBook = excelApp.Workbooks[ 1 ];
2 workBook.RefreshAll();

  之后的保存,也有两种方法:

  1.直接保存,当之前通过Open方法创建Excel文件,并没有设为只读时,可以用这种方法,比较简单:

 
 
1 Workbook workBook = excelApp.Workbooks[ 1 ];
2 workBook.Save();

  2.这一种方法的比较灵活,就是SaveAs(),相当于界面操作的另存为,但这个方法的问题和创建Workbook时的第一种方法一样,参数比较多,虽然大部分可以用miss

 
 
1 Workbook workBook = excelApp.Workbooks[ 1 ];
2   object miss = Missing.Value;
3 workBook.SaveAs(path, miss, miss, miss, miss, miss, XlSaveAsAccessMode.xlNoChange, miss, miss, miss, miss, miss);

  保存之后要关闭WorkBook:

 
 
1 workBook.Close( false , miss, miss);
2 workBook = null;

7.最后需要清空内存

 
  
1 excelApp.Quit();
2 excelApp = null;
3 GC.Collect();
目录
相关文章
|
24天前
|
SQL 小程序 API
如何运用C#.NET技术快速开发一套掌上医院系统?
本方案基于C#.NET技术快速构建掌上医院系统,结合模块化开发理念与医院信息化需求。核心功能涵盖用户端的预约挂号、在线问诊、报告查询等,以及管理端的排班管理和数据统计。采用.NET Core Web API与uni-app实现前后端分离,支持跨平台小程序开发。数据库选用SQL Server 2012,并通过读写分离与索引优化提升性能。部署方案包括Windows Server与负载均衡设计,确保高可用性。同时针对API差异、数据库老化及高并发等问题制定应对措施,保障系统稳定运行。推荐使用Postman、Redgate等工具辅助开发,提升效率与质量。
|
4月前
|
开发框架 算法 .NET
C#/.NET/.NET Core技术前沿周刊 | 第 15 期(2024年11.25-11.30)
C#/.NET/.NET Core技术前沿周刊 | 第 15 期(2024年11.25-11.30)
|
4月前
|
开发框架 Cloud Native .NET
C#/.NET/.NET Core技术前沿周刊 | 第 16 期(2024年12.01-12.08)
C#/.NET/.NET Core技术前沿周刊 | 第 16 期(2024年12.01-12.08)
|
4月前
|
数据采集 数据可视化 数据挖掘
利用Python自动化处理Excel数据:从基础到进阶####
本文旨在为读者提供一个全面的指南,通过Python编程语言实现Excel数据的自动化处理。无论你是初学者还是有经验的开发者,本文都将帮助你掌握Pandas和openpyxl这两个强大的库,从而提升数据处理的效率和准确性。我们将从环境设置开始,逐步深入到数据读取、清洗、分析和可视化等各个环节,最终实现一个实际的自动化项目案例。 ####
622 10
|
6月前
|
数据采集 存储 JavaScript
自动化数据处理:使用Selenium与Excel打造的数据爬取管道
本文介绍了一种使用Selenium和Excel结合代理IP技术从WIPO品牌数据库(branddb.wipo.int)自动化爬取专利信息的方法。通过Selenium模拟用户操作,处理JavaScript动态加载页面,利用代理IP避免IP封禁,确保数据爬取稳定性和隐私性。爬取的数据将存储在Excel中,便于后续分析。此外,文章还详细介绍了Selenium的基本设置、代理IP配置及使用技巧,并探讨了未来可能采用的更多防反爬策略,以提升爬虫效率和稳定性。
393 4
|
2月前
|
分布式计算 Hadoop 大数据
从Excel到Hadoop:数据规模的进化之路
从Excel到Hadoop:数据规模的进化之路
59 10
|
4月前
|
存储 Java easyexcel
招行面试:100万级别数据的Excel,如何秒级导入到数据库?
本文由40岁老架构师尼恩撰写,分享了应对招商银行Java后端面试绝命12题的经验。文章详细介绍了如何通过系统化准备,在面试中展示强大的技术实力。针对百万级数据的Excel导入难题,尼恩推荐使用阿里巴巴开源的EasyExcel框架,并结合高性能分片读取、Disruptor队列缓冲和高并发批量写入的架构方案,实现高效的数据处理。此外,文章还提供了完整的代码示例和配置说明,帮助读者快速掌握相关技能。建议读者参考《尼恩Java面试宝典PDF》进行系统化刷题,提升面试竞争力。关注公众号【技术自由圈】可获取更多技术资源和指导。
|
8月前
|
关系型数据库 MySQL Shell
不通过navicat工具怎么把查询数据导出到excel表中
不通过navicat工具怎么把查询数据导出到excel表中
85 0
|
6月前
|
数据处理 Python
Python实用记录(十):获取excel数据并通过列表的形式保存为txt文档、xlsx文档、csv文档
这篇文章介绍了如何使用Python读取Excel文件中的数据,处理后将其保存为txt、xlsx和csv格式的文件。
351 3
Python实用记录(十):获取excel数据并通过列表的形式保存为txt文档、xlsx文档、csv文档
|
6月前
|
easyexcel Java UED
SpringBoot中大量数据导出方案:使用EasyExcel并行导出多个excel文件并压缩zip后下载
在SpringBoot环境中,为了优化大量数据的Excel导出体验,可采用异步方式处理。具体做法是将数据拆分后利用`CompletableFuture`与`ThreadPoolTaskExecutor`并行导出,并使用EasyExcel生成多个Excel文件,最终将其压缩成ZIP文件供下载。此方案提升了导出效率,改善了用户体验。代码示例展示了如何实现这一过程,包括多线程处理、模板导出及资源清理等关键步骤。
下一篇
oss创建bucket