Visual C# 编程操作Excel

引言

  Excel是微软公司办公自动化套件中的一个软件,他主要是用来处理电子表格。Excel以其功能强大,界面友好等受到了许多用户的欢迎。在设计应用系统时,对于不同的用户,他们对于打印的需求是不一样的,如果要使得程序中的打印功能适用于每一个用户,可以想象程序设计是十分复杂的。由于Excel表格的功能强大,又由于几乎每一台机器都安装了它,如果把程序处理的结果放到Excel表格中,这样每一个用户就可以根据自己的需要在Excel中定制自己的打印。这样不仅使得程序设计简单,而且又满足了诸多用户的要求,更加实用了。那么用Visual C#如何调用Excel,如何又把数据存放到Excel表格中?本文就来探讨上述问题的解决办法。

  Excel对象

  微软的Excel对象模型包括了128个不同的对象,从矩形,文本框等简单的对象到透视表,图表等复杂的对象.下面我们简单介绍一下其中最重要,也是用得最多的四个对象。

  (1) Application对象。Application对象处于Excel对象层次结构的顶层,表示Excel自身的运行环境。

  (2) Workbook对象。Workbook对象直接地处于Application对象的下层,表示一个Excel工作薄文件。

  (3) Worksheet对象。Worksheet对象包含于Workbook对象,表示一个Excel工作表。

  (4) Range对象。Range对象包含于Worksheet对象,表示Excel工作表中的一个或多个单元格。专题:http://www.qqread.com/csharp/i520995000.html 更多内容请看Java编程开发手册专题,或进入讨论组讨论。

  在.NET公用语言框架内运行的程序为受管代码。受管代码在程序中所有类型都受到严格检查,没有指针,对内存的管理完全由运行系统控制。

  受控状态下,编写程序更为容易,且更少出错,我们可以花更多的时间在解决实际问题上而不是在计算机语言问题上。相对而言,那些在.NET框架外运行的程序为非受管代码。比如:COM组件、ActiveX组件、Win32 API函数、指针运算等。C#编程中在某些特定情况下,需要运用非受管代码,例如,要利用一个成熟的COM组件,或者调用一个API函数,或者用指针去编写实时/高效程序等。

  Visual C#中调用ExcelCOM组件

  一个.NET组件事实上是一个.NET下的DLL,它包含的不仅是运行程序本身,更重要的是包含这个DLL的描述信息(Meta Data,即元数据),而一个COM组件是用其类库(TLB)储存其描述信息。这些COM组件都是非受管代码,要在Visual C#中使用这些非受管代码的COM组件,就必须把他们转换成受管代码的.NET组件。所以在用Visual C#调用Excel表格之前,必须完成从COM组件的非受管代码到受管代码的类库的转换。

  1、将ExcelCOM组件转换为.NET组件

  在项目中打开Add Reference对话框,选择COM栏,之后在COM列表中找到"Microsoft Excel 9.0 Object Library"Office2000),然后将其加入到项目的References中即可。Visual C#.NET会自动产生相应的.NET组件文件,以后即可正常使用。

  这个转换形成.NET组件不能单独使用,它不过是以前的COM组件的一个外层包装,在.NET中可以通过这个外层包装去发现原来的COM组件并调用其相应的界面函数。所以它必须与原来的COM组件一起起作用。

  2Visual C#打开Excel表格

  事实上,在C#中使用一个经转换的COM组件和使用任何一个其它.NET组件完全一样。可以用new关键字创建一个经转换的COM组件,然后再像使用任何一个其它C#对象一样使用这个组件对象。

  在转换后的.NET组件中定义了一个命名空间Excel,在此命名空间中封装了一个类Application,这个类和启动Excel表格有非常重要的关系,在Visual C#中,只需要下列三行代码就可以完成打开Excel表格的工作,具体如下:

  Excel.Application excel = new Excel.Application ()//引用Excel对象

  excel.Application.Workbooks.Add ( true )//引用Excel工作簿

  excel.Visible = true //使Excel可视

  但此时的Excel表格是一个空的表格,没有任何内容,下面就来介绍如何往Excel表格中输入数据。

  3、往Excel表格中输入数据

在命名空间"Excel"中,还定义了一个类"Cell",这个类所代表的就是Excel表格中的一个单元格。通过给"Cell"赋值,从而实现往Excel表格中输入相应的数据,下列代码功能是打开Excel表格,并且往表格输入一些数据。

  Excel.Application excel = new Excel.Application ()

  excel.Application.Workbooks.Add ( true )

  excel.Cells[ 1 , 1 ] = "First Row First Column"

  excel.Cells[ 1 , 2 ] = "First Row Second Column"

  excel.Cells[ 2 , 1 ] = "Second Row First Column"

  excel.Cells[ 2 , 2 ] = "Second Row Second Column"

  excel.Visible = true ;

  保留地址 http://www.qqread.com/csharp/i520995000.html 更多内容请看Java编程开发手册专题,或进入讨论组讨论。

  string cnString="Provider=msdaora.1;Data source=Name; ";

  cnString=cnString+"user id=UserName;password=Password";

  try

  {

  OleDbConnection cn=new OleDbConnection (cnString);

  cn.Open ();

  try

  {

  string s="select * from Name.TableName";

  OleDbCommand cmd=new OleDbCommand (s,cn);

  OleDbDataReader dr=cmd.ExecuteReader ();

  Excel.Application xlApp = new Excel.Application();

  if(xlApp==null){MessageBox.Show ("Can't open Excel!");return;}

  xlApp.Application .Workbooks .Add (true);

  int row=2,fieldcount;

  fieldcount=dr.FieldCount ;

  for(int col=0;col

  while (dr.Read ())

  {

  for(int col=0;col< p>

  xlApp.Cells [row,col+1]=dr.GetValue(col).ToString();

  row++;

  }

  xlApp.Visible =true;

  xlApp=null;

  }

  catch(Exception ex ){MessageBox.Show (ex.Message );}

  finally {cn.Close();}

  }

  catch(Exception ex){MessageBox.Show (ex.Message );}

  }

  }

  5、安装一个使用COM组件的.NET程序

如果要将这样的程序安装运行在另一台机器上,那么除了安装运行程序外,还做三件事。

  首先,是安装.NET运行系统。因为任何一个.NET程序都不能离开.NET运行系统去独立运行。

  其次,所调用的COM组件必须要安装在目标机器上。本例中大多数目标机器上都装有MicrosoftOfficeExcel,一般不会有这个问题。但如果是另一个用户自定义的COM组件,那么这个COM组件在运行.NET程序之前必须先安装好。

  最后,转换后的.NET组件DLL文件要安装在目标机器上。因为.NET组件不需要在Windows Registry中注册,所以最简单的方法是将.NET组件DLL文件拷贝到运行程序目录下。如果此.NET组件被多个.NET程序共享,可以将其安装在.NET公用组件区中,从而可被任何一个.NET组件使用。只有当一个.NET组件参与了事务处理时,才需要将它注册为一个COM+组件。因为.NET仍然用传统的COM+机制来处理事务的提交、回滚等。

  小结

  通过以上讨论,我们知道了在C#中,如何使用ExcelCOM组件。需要注意的是,Excel对象包含的许多内容我们没有介绍,在使用过程中需要我们不断学习。也使我们了解了在C#中如何使用COM组件

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C# VSTO (Visual Studio Tools for Office) 是一种用于开发 Microsoft Office 应用程序的技术框架,其中包括 ExcelVSTO 提供了一组强大的工具和功能,使开发人员能够使用 C# 编程语言来创建自定义的 Excel 解决方案。 通过使用 C# VSTO,您可以利用 Excel 的功能和数据处理能力,以及自定义用户界面和业务逻辑,创建各种类型的 Excel 插件和扩展。以下是一些 C# VSTO 开发 Excel 的常见功能和用途: 1. 自定义功能:您可以使用 C# VSTO 创建自定义函数,以扩展 Excel 的内置函数库。这样,您可以根据特定需求创建自定义计算公式,并在 Excel 中使用它们。 2. 数据操作C# VSTO 允许您通过编程方式读取、写入和操作 Excel 工作簿中的数据。您可以使用 C# 代码来执行各种数据操作,如读取单元格值、设置单元格格式、创建图表等。 3. 用户界面定制:通过 C# VSTO,您可以创建自定义的 Excel 用户界面,包括自定义的菜单、工具栏、任务窗格等。这样,您可以根据特定需求为用户提供更直观和易用的界面。 4. 事件处理:C# VSTO 允许您订阅 Excel 中的各种事件,如工作簿打开、单元格更改等。通过事件处理,您可以在特定事件发生时执行自定义的操作,以响应用户的操作或特定的工作簿状态。 5. 数据交互:C# VSTO 可以与其他数据源进行交互,如数据库、Web 服务等。您可以使用 C# 代码将 Excel 中的数据与其他系统进行集成和交互,实现数据的导入、导出和同步等功能。 总之,C# VSTO 提供了丰富的功能和灵活性,使开发人员能够以 C# 编程语言创建强大的 Excel 解决方案。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值