由于要为某软件实现导出Excel功能,故有此文。

本文的开发环境是Visual Studio 2010 ,C#, Excel 2007。

新建C#工程后打开Solution Explorer,可以看到如下图片:

右键点击Reference->Add References->Browse

选择三个DLL文件(点此下载):

Interop.Excel.dll

Interop.Microsoft.Office.Core.dll

Interop.VBIDE.dll

添加上述三个引用后,Reference标签里的内容如下:

可以看到已经引用了刚才添加的三个DLL文件。OK,下面可以开始写代码了。

首先,在Form1.cs中添加Excel命名空间

  1. using Excel;

1.新建一个Excel文档并向其中写入内容

下面,为Form1添加Load消息响应函数,添加方法如下所示:

对应的Office_test1_Load函数如下:

  1. private Excel.Application      m_excel;
  2. private void Office_test1_Load(object sender, EventArgs e)
  3. {
  4. m_excel     =   new     Excel.Application();
  5. m_excel.Application.Workbooks.Add(true);
  6. int col;
  7. for (col = 0; col < 10; col++)
  8. {
  9. m_excel.Cells[1, col + 1] = col;
  10. }
  11. //显示Excel内容
  12. m_excel.Visible = true;
  13. }

编译,运行,得到如下效果:

通过上图可以看到一个新的Excel文档被创建了。下面我们再来看看如何打开一个已有的Excel文档。

2.打开一个已有Excel文档并读取其中内容

在读取Excel文档之前,先来观察一下待读取的文档。

如图所示,第一行为标题,第二行为数据。此外,留意一下第一列的内容类型为:”日期“,第三列类型为:”数值“

按照常理,首先添加一个打开按钮,对应OnOpen()监听器。

类成员定义:

  1. private Excel.Application      m_excel;
  2. private Excel.Workbook         m_workbook;

此外,在Onload函数中要实例化m_excel。

  1. private void OnOpen(object sender, EventArgs e)
  2. {
  3. m_workbook = m_excel.Workbooks.Open(
  4. "C:\\Users\\David_ss\\Desktop\\项目管理\\项目经费收入简表.xlsx",
  5. Type.Missing, Type.Missing, Type.Missing, Type.Missing,
  6. Type.Missing, Type.Missing, Type.Missing, Type.Missing,
  7. Type.Missing, Type.Missing, Type.Missing, Type.Missing,
  8. Type.Missing, Type.Missing);
  9. m_excel.Visible = true;
  10. }

下面,我们要进行文档的读取了。

为了显示内容,我新添了几个控件:如下图所示

然后我们完成 ”显示值“按钮对应的消息响应函数 OnShowValue()

  1. private void OnShowValue(object sender, EventArgs e)
  2. {
  3. Range rng;
  4. object obj;
  5. String str;
  6. rng = (Excel.Range)m_excel.Cells[2, 1];
  7. obj = rng.Value2;
  8. System.Diagnostics.Debug.WriteLine(obj.ToString());
  9. str = rng.NumberFormatLocal;
  10. System.Diagnostics.Debug.WriteLine(str);
  11. this.date_ctrl.Value = DateTime.FromOADate(double.Parse(obj.ToString()));
  12. rng = (Excel.Range)m_excel.Cells[2, 2];
  13. obj = rng.Value2;
  14. System.Diagnostics.Debug.WriteLine(obj.ToString());
  15. str = rng.NumberFormatLocal;
  16. System.Diagnostics.Debug.WriteLine(str);
  17. this.serialnumber_ctrl.Text = obj.ToString();
  18. rng = (Excel.Range)m_excel.Cells[2, 3];
  19. obj = rng.Value2;
  20. System.Diagnostics.Debug.WriteLine(obj.ToString());
  21. str = rng.NumberFormatLocal;
  22. System.Diagnostics.Debug.WriteLine(str);
  23. this.money_ctrl.Text = obj.ToString();
  24. rng = (Excel.Range)m_excel.Cells[2, 4];
  25. obj = rng.Value2;
  26. System.Diagnostics.Debug.WriteLine(obj.ToString());
  27. str = rng.NumberFormatLocal;
  28. System.Diagnostics.Debug.WriteLine(str);
  29. this.manager_ctrl.Text = obj.ToString();
  30. }

上面代码分别对应4个控件的数据显示。

下面是显示的结果:

此外,上面的代码中,我还输出了调试信息,即每个单元格的数据类型:

  1. str = rng.NumberFormatLocal;
  2. System.Diagnostics.Debug.WriteLine(str);

调试输出结果:

通过上述结果可以看出:日期格式是日期对应的是一个数字字符串。所以代码中使用的是DateTime的FromOADate方法解析日期。

日期的格式为:yyyy/m/d。

一般的单元格类型是:G/通用格式

数值格式为:0.00_);[红色](0.00)。

-------------------------------------------------------华丽分割-------------------------------------------

若想要了解更多,首先请学习一下Excel的对象模型,可以参考上一篇文章:

当然,也可以下载对应的文档:C#操作Excel2007&Excel对象模型.pdf

C#操作Excel(2)-- 打开-读取Excel文档的更多相关文章

  1. C#操作Word (2)-- 打开&关闭Word文档

    本文正式开始在VS2010中使用C#语言操作Word2007. 不是十分了解Word对象模型的朋友,请参考上一篇文章,或者下载:C#操作Word2007.pdf. ------------------ ...

  2. VBS读取txt文档数据查找Excel中单元格数据符合条件的剪切到工作表2中

    Dim fso,f,a set oExcel = CreateObject( "Excel.Application" ) oExcel.Visible = false '4) 打开 ...

  3. 使用Apache POI导出Excel小结--导出XLS格式文档

    使用Apache POI导出Excel小结 关于使用Apache POI导出Excel我大概会分三篇文章去写 使用Apache POI导出Excel小结--导出XLS格式文档 使用Apache POI ...

  4. Unity用Excel.dll简单读取Excel内容

    Unity用Excel.dll简单读取Excel内容 需要Excel.dll 需要如下三个命名空间 using System.IO; using Excel; using System.Data; 1 ...

  5. java中XML操作:xml与string互转、读取XML文档节点及对XML节点增删改查

    一.XML和String互转: 使用dom4j程式变得很简单 //字符串转XML String xmlStr = \"......\"; Document document = D ...

  6. java中读取word文档里的内容

    package com.cn.peitest.excel.word; import java.io.FileInputStream; import java.io.FileOutputStream; ...

  7. 【Win10 开发】读取PDF文档

    关于用来读取PDF文档的内容的API,其实在Win8.1的时候就有,不过没关系,既咱们讨论的是10的UAP,连同8.1的内容也包括进去,所以老周无数次强调:把以前的内容学好了,就可以在不学习任何新知识 ...

  8. Python读取word文档(python-docx包)

    最近想统计word文档中的一些信息,人工统计的话...三天三夜吧 python 不愧是万能语言,发现有一个包叫做 docx,非常好用,具体查看官方文档:https://python-docx.read ...

  9. ASP 读取Word文档内容简单示例

    以下通过Word.Application对象来读取Doc文档内容并显示示例. 下面进行注册Word组件:1.将以下代码存档命名为:AxWord.wsc XML code复制代码 <?xml ve ...

随机推荐

  1. HDU5807 Keep In Touch (BestCoder Round #86 D ) 分布式dp

    #include <cstdio> #include <cstring> #include <cmath> #include <vector> #inc ...

  2. UIButton 在UIScrollView里面 点击效果不明显的问题

    self.scrollView.delaysContentTouches = NO; -(BOOL)touchesShouldCancelInContentView { return YES; }

  3. java解析properties文件

    在自动化测试过程中,经常会有一些公用的属性要配置,以便后面给脚本使用,我们可以选择xml, excel或者json格式来存贮这些数据,但其实java本身就提供了properties类来处理proper ...

  4. 自动抓取java堆栈

    参数1 进程名字,参数2 最大线程数 例: pid为8888,达到1000个线程时自动抓取堆栈信息 ./autojstack.sh 8888 1000 & #!/bin/bashfileNam ...

  5. dzzoffice教程、文档、开发手册等内容地址

    dzzoffice教程.文档.开发手册等内容全部都存放在DzzOffice开发者社区的文集中.搜索引擎收录不到DzzOffice中的应用内容,这里将文集地址提供在这里. 地址:http://dev.d ...

  6. linux 后台运行程序

    有些时候,我们需要在终端启动一个程序,并使之运行--但是如果关闭终端,那么这个程序也就随着关闭了.那么有没有什么方法在关闭终端后,让已经从这个终端启动的程序继续运行呢? 前置知识: xterm,con ...

  7. CreateProcess error=206, The filename or extension is too long"的一个解决方案

    在实际项目中我使用antrun 和 closure-compiler压缩JS项目.然后我就使用如下代码: 首先加入依赖. <dependency> <groupId>com.g ...

  8. .NET在IE9中页面间URL传递中文变成乱码的解决办法

     在.Net的项目中,鼠标点击查询按钮,转到查询页面,但URL中包含中文时,传到服务器端后,中文变成了乱码(只有IE9出现该问题).       尝试使用Server.UrlEncode()进行编码, ...

  9. 得到python某个模块的路径

    #-*-coding:utf-8-*- # 导入imp模块 import imp # 打印出MySQLdb模块 print imp.find_module("MySQLdb")

  10. 谷歌眼镜--UI指南

    1>使用玻璃HTML模板 不是所有的内容都在几行文字来表达.有时候你需要结构化的内容发送到用户的时间轴,或者你需要控制对格式.为了适应这种情况,镜像API提供了一个 HTML 时间表的项目,接受 ...