一.COM interop

首先我们要了解下何为COM Interop,它是一种服务,可以使.NET Framework对象能够与COM对象通信。Visual Studio .NET 通过引入面向公共语言运行时的托管代码概念,改变了开发人员在创建和运行应用程序的方式。但是这也使得它与基于Windows API和COM对象的编程有了本质的去比。Visual Studio .NET让托管对象和非托管对象协同工作的过程能够称为互用性(interoperability),通常简称为interop。

 
二.Excel COM命名空间
  Microsoft.Office.Interop.Excel
 
 关键点:
保存excel的时候,使用SaveAs()或SaveCopyAs(),都是新建一个文件,然后将其保存起来
Application.Quit(),因为是非托管的,未释放对象,不能保证完全退出进程。1)可以使用KillProcess(),但有可能误终止其它excel进程 2)将Application实例设为null。
 
 
具体实现过程:
1.这里,把对excel表格的操作封装在一个叫ExcelOperator的类当中,该类主要具有如下方法。当然还有其它辅助方法,会在具体实现的时候展开。
 class ExcelOperator
{
//构造函数,列名为输入参数
public ExcelOperator(List<string> _columnHeader)
{
this.ColumnHeader = _columnHeader;
}
//打开Excel表头
public void OpenExcel();
//输入一条行记录值
public bool ExportToExcel<T>(IEnumerable<T> _records);
//保存并关闭
public bool SaveAndClose();
}
2.在后台打开excel表格:生成一个新excel进程--->取消确认对话框--->给该进程添加一个workbook--->获取该workbook的worksheet(默认情况下一个新建的workbook有一个worksheet)--->格式化表格。具体代码如下:
 public void OpenExcel()
{
excelProcess = new ExcelNameSpace.Application();
if (excelProcess == null) throw new Exception("Excel Application is NULL");
try
{
excelProcess.Visible = false;
//取消提示,可以直接保存修改后的表格,重要
excelProcess.DisplayAlerts = false;
excelProcess.AlertBeforeOverwriting = false;
workbook = excelProcess.Workbooks.Add();
worksheet = workbook.Sheets.get_Item();
worksheet.Name = FileName;
if (worksheet == null) throw new Exception("Excel WorkSheet is NULL");
//自动填充表头或其它内容操作
InitialWorkSheet();
//格式化excel表单
FormatWorkSheet();
this.flagIsOpen = true;
}
catch (Exception e)
{
......
}
}

大家可以注意到,以上方法还有两个子方法,下面把两个子方法的实现过程简单介绍下:

         /// <summary>
/// 填充excel表头名称
/// </summary>
virtual protected void InitialWorkSheet()
{
startRow = ;
startColumn = ;
this.worksheet.Cells[startRow, startColumn].Select();
foreach (string header in this.ColumnHeader)
{
this.excelProcess.ActiveCell.Value = header;
this.excelProcess.ActiveCell.Offset[, ].Select();
}
startRow++;
} /// <summary>
/// 格式化表格
/// </summary>
virtual protected void FormatWorkSheet()
{
//水平居中
this.worksheet.Cells.HorizontalAlignment = ExcelNameSpace.XlVAlign.xlVAlignCenter;
//设置列名框颜色
var hCell = worksheet.Cells[, this.ColumnHeader.Count];
this.excelProcess.Range["A1", hCell].Interior.ColorIndex = ;
this.excelProcess.Range["A1", hCell].Borders.LineStyle = ;
this.excelProcess.Range["A1", hCell].Borders[ExcelNameSpace.XlBordersIndex.xlEdgeLeft].Weight = ExcelNameSpace.XlBorderWeight.xlThin;
......
}

在InitialWorkSheet()方法中,可以看到有两个全局变量startRow和startColumn,这两个变量就是用来记录下一个有效输入的位置的。

3.插入行记录,我在这里是想实现批量插入记录的功能。为了方便使用,首先编写了一个Record类,含有一个List<string>成员,用来记录单独一行的记录。然后在传入一个List<Record>的参数。其实简单点,直接传输一个List<string>参数,每次单独加一条记录也可以了。不过为了练习。具体代码如下:

         /// <summary>
/// 利用Record集合添加记录
/// </summary>
virtual public bool ExportToExcel<T>(IEnumerable<T> _records) where T : Record
{
try
{
this.worksheet.Cells[startRow, startColumn].Select();
foreach (var record in _records)
{
this.worksheet.Cells[startRow, startColumn].Select();
foreach (var item in record)
{
this.excelProcess.ActiveCell.Value = item;
this.excelProcess.ActiveCell.Offset[, ].Select();
}
startRow++;
}
return true;
}
catch(Exception e)
{
......
}
}

4.保存并关闭:

         public bool SaveAndClose()
{
//用另存为的方式保存共工作簿,利用GenerateFileURL()产生文件存储路径
this.workbook.SaveAs(GenerateFileURL());
this.workbook.Close();
this.flagIsOpen = false;
         //关闭进程
this.excelProcess.Quit();
         //保证释放非托管对象
System.Runtime.InteropServices.Marshal.ReleaseComObject(this.excelProcess);
this.excelProcess = null;
return true;
}

5.ExcelOperator类还包含了FileName(文件名)、FilePath(文件存储路径)等属性,请自行进行实现。

利用C#实现对excel的写操作的更多相关文章

  1. 通过vb.net 和NPOI实现对excel的读操作

    通过vb.net 和NPOI实现对excel的读操作,很久很久前用过vb,这次朋友的代码是vb.net写的需要一个excel的操作, 就顾着着实现功能了,大家凑合着看吧 Option Explicit ...

  2. 使用jxl操作之一: 实现对Excel简单读写操作

    项目目录树 对象类UserObject UserObject.java package com.dlab.jxl; public class UserObject { private String u ...

  3. 使用POI来实现对Excel的读写操作

    事实上我感觉直接贴代码就好了.代码里面差点儿做到每一行一个凝视.应该看起来会比較简单 代码托管在github上:https://github.com/chsj1/ExcelUtils package ...

  4. JAVA-----基于POI实现对Excel导入

    在日常项目开发中, 数据录入和导出是十分普遍的需求,因此,导入导出也成为了开发中一个经典的功能.数据导出的格式一般是excel或者pdf,而批量导入的信息一般是借助excel来减轻工作量,提高效率. ...

  5. Python中实现对list做减法操作介绍

    Python中实现对list做减法操作介绍 这篇文章主要介绍了Python中实现对list做减法操作介绍,需要的朋友可以参考下 问题描述:假设我有这样两个list, 一个是list1,list1 = ...

  6. Excel操作类库最常用到的4种开源项目与MS Excel类库写操作对比分析性能

    4种开源Excel读写类库与MS Excel类库写操作对比 软件开发过程中,经常需要将数据保存为.xls或.xlsx文件.之前发现微软提供的Microsoft.Office.Interop.Excel ...

  7. Python实现对excel的操作

    1.操作excel使用第三方库openpyxl安装:pip install openpyxy引入:import openpyxl2.常用简单操作1)打开excel文件获取工作簿wb = openpyx ...

  8. 使用代理实现对C# list distinct操作

    范型在c#编程中经常使用,而经常用list 去存放实体集,因此会设计到对list的各种操作,比较常见的有对list进行排序,查找,比较,去重复.而一般的如果要对list去重复如果使用linq dist ...

  9. 在Asp.Net MVC中使用NPOI插件实现对Excel的操作(导入,导出,合并单元格,设置样式,输入公式)

    前言 NPOI 是 POI 项目的.NET版本,它不使用 Office COM 组件,不需要安装 Microsoft Office,目前支持 Office 2003 和 2007 版本. 1.整个Ex ...

随机推荐

  1. poj2387 Til the Cows Come Home

    解题思路:最短路的模板题,注意一个细节处理即可. 见代码: #include<cstdio> #include<cstring> #include<algorithm&g ...

  2. [转]glew, glee与 gl glu glut glx glext的区别和关系

    原文地址:http://blog.csdn.net/delacroix_xu/article/details/5881942 因为也是初接触,所以就当了解,等深入学习后再回顾这篇文章观点. GLEW是 ...

  3. yii2.0 输出url 注册js css文件

    //输出url <a href="<?=  Url::to(['/users/login/login','id'=>5,'mark'=>true]) ?>&qu ...

  4. jsonp实现跨域访问

    要实现JSONP跨域访问,首先就要了解什么是跨域?然后JSONP与JSON的关系? 1.什么是跨域? 跨域简单的说就是一个域名下的程序和另一个域名下的程序做数据交互.比如说:现有一个http://ww ...

  5. BroadcastReceiver应用详解

    今天我们来讲一下Android中BroadcastReceiver的相关知识. BroadcastReceiver也就是“广播接收者”的意思,顾名思义,它就是用来接收来自系统和应用中的广播. 在And ...

  6. 模式自由(Schema-free)和数据存储的非格式化趋势

    最近遐想,数据存储的非格式化趋势. 格式化表格到自由的XML存储 数年以前,多家数据库厂商开始XML数据库存储.XML数据作为一种自描述的半结构化数据为Web的数据管理提供了新的数据模型,如果将XML ...

  7. [讲座]【项目收集】“清流资本”互联网金融沙龙——颠覆者的创新与机会

    [项目收集]"清流资本"互联网金融沙龙--颠覆者的创新与机会 2014年4月19日 14:00 - 2014年4月19日 17:00 北京海淀北京海淀区海淀图书城南侧3W咖啡 限额 ...

  8. cocos2dx 2.x 版本+Windows+ADT Bundle 配置

    昨天解决了cocos2dx 3.x版本+Windows+ADT Bundle的配置,今天来解决cocos2dx 2.x版本的配置. 整体来说,2.x的配置相对麻烦一点,不过一旦解决了,就一路畅通无阻了 ...

  9. LoadRunner error -27498

    URL=http://172.18.20.70:7001/workflow/bjtel/leasedline/ querystat/ subOrderQuery.do错误分析:这种错误常常是因为并发压 ...

  10. dzzoffice的树型结构用户管理设计

    在DzzOffice1.1的开发中,针对用户使用群体重新设计了,机构.部门.用户管理应用. 传统OA,企业相关程序,一般是设置机构-设置部门-设置职位-添加用户这样的步骤.每个步骤分为不同的管理界面. ...