C#操作Excel(2)-- 打开-读取Excel文档
由于要为某软件实现导出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命名空间
- using Excel;
1.新建一个Excel文档并向其中写入内容
下面,为Form1添加Load消息响应函数,添加方法如下所示:

对应的Office_test1_Load函数如下:
- private Excel.Application m_excel;
- private void Office_test1_Load(object sender, EventArgs e)
- {
- m_excel = new Excel.Application();
- m_excel.Application.Workbooks.Add(true);
- int col;
- for (col = 0; col < 10; col++)
- {
- m_excel.Cells[1, col + 1] = col;
- }
- //显示Excel内容
- m_excel.Visible = true;
- }
编译,运行,得到如下效果:

通过上图可以看到一个新的Excel文档被创建了。下面我们再来看看如何打开一个已有的Excel文档。
2.打开一个已有Excel文档并读取其中内容
在读取Excel文档之前,先来观察一下待读取的文档。

如图所示,第一行为标题,第二行为数据。此外,留意一下第一列的内容类型为:”日期“,第三列类型为:”数值“
按照常理,首先添加一个打开按钮,对应OnOpen()监听器。
类成员定义:
- private Excel.Application m_excel;
- private Excel.Workbook m_workbook;
此外,在Onload函数中要实例化m_excel。
- private void OnOpen(object sender, EventArgs e)
- {
- m_workbook = m_excel.Workbooks.Open(
- "C:\\Users\\David_ss\\Desktop\\项目管理\\项目经费收入简表.xlsx",
- Type.Missing, Type.Missing, Type.Missing, Type.Missing,
- Type.Missing, Type.Missing, Type.Missing, Type.Missing,
- Type.Missing, Type.Missing, Type.Missing, Type.Missing,
- Type.Missing, Type.Missing);
- m_excel.Visible = true;
- }
下面,我们要进行文档的读取了。
为了显示内容,我新添了几个控件:如下图所示

然后我们完成 ”显示值“按钮对应的消息响应函数 OnShowValue()
- private void OnShowValue(object sender, EventArgs e)
- {
- Range rng;
- object obj;
- String str;
- rng = (Excel.Range)m_excel.Cells[2, 1];
- obj = rng.Value2;
- System.Diagnostics.Debug.WriteLine(obj.ToString());
- str = rng.NumberFormatLocal;
- System.Diagnostics.Debug.WriteLine(str);
- this.date_ctrl.Value = DateTime.FromOADate(double.Parse(obj.ToString()));
- rng = (Excel.Range)m_excel.Cells[2, 2];
- obj = rng.Value2;
- System.Diagnostics.Debug.WriteLine(obj.ToString());
- str = rng.NumberFormatLocal;
- System.Diagnostics.Debug.WriteLine(str);
- this.serialnumber_ctrl.Text = obj.ToString();
- rng = (Excel.Range)m_excel.Cells[2, 3];
- obj = rng.Value2;
- System.Diagnostics.Debug.WriteLine(obj.ToString());
- str = rng.NumberFormatLocal;
- System.Diagnostics.Debug.WriteLine(str);
- this.money_ctrl.Text = obj.ToString();
- rng = (Excel.Range)m_excel.Cells[2, 4];
- obj = rng.Value2;
- System.Diagnostics.Debug.WriteLine(obj.ToString());
- str = rng.NumberFormatLocal;
- System.Diagnostics.Debug.WriteLine(str);
- this.manager_ctrl.Text = obj.ToString();
- }
上面代码分别对应4个控件的数据显示。
下面是显示的结果:

此外,上面的代码中,我还输出了调试信息,即每个单元格的数据类型:
- str = rng.NumberFormatLocal;
- System.Diagnostics.Debug.WriteLine(str);
调试输出结果:
通过上述结果可以看出:日期格式是日期对应的是一个数字字符串。所以代码中使用的是DateTime的FromOADate方法解析日期。
日期的格式为:yyyy/m/d。
一般的单元格类型是:G/通用格式
数值格式为:0.00_);[红色](0.00)。
-------------------------------------------------------华丽分割-------------------------------------------
若想要了解更多,首先请学习一下Excel的对象模型,可以参考上一篇文章:
当然,也可以下载对应的文档:C#操作Excel2007&Excel对象模型.pdf
C#操作Excel(2)-- 打开-读取Excel文档的更多相关文章
- C#操作Word (2)-- 打开&关闭Word文档
本文正式开始在VS2010中使用C#语言操作Word2007. 不是十分了解Word对象模型的朋友,请参考上一篇文章,或者下载:C#操作Word2007.pdf. ------------------ ...
- VBS读取txt文档数据查找Excel中单元格数据符合条件的剪切到工作表2中
Dim fso,f,a set oExcel = CreateObject( "Excel.Application" ) oExcel.Visible = false '4) 打开 ...
- 使用Apache POI导出Excel小结--导出XLS格式文档
使用Apache POI导出Excel小结 关于使用Apache POI导出Excel我大概会分三篇文章去写 使用Apache POI导出Excel小结--导出XLS格式文档 使用Apache POI ...
- Unity用Excel.dll简单读取Excel内容
Unity用Excel.dll简单读取Excel内容 需要Excel.dll 需要如下三个命名空间 using System.IO; using Excel; using System.Data; 1 ...
- java中XML操作:xml与string互转、读取XML文档节点及对XML节点增删改查
一.XML和String互转: 使用dom4j程式变得很简单 //字符串转XML String xmlStr = \"......\"; Document document = D ...
- java中读取word文档里的内容
package com.cn.peitest.excel.word; import java.io.FileInputStream; import java.io.FileOutputStream; ...
- 【Win10 开发】读取PDF文档
关于用来读取PDF文档的内容的API,其实在Win8.1的时候就有,不过没关系,既咱们讨论的是10的UAP,连同8.1的内容也包括进去,所以老周无数次强调:把以前的内容学好了,就可以在不学习任何新知识 ...
- Python读取word文档(python-docx包)
最近想统计word文档中的一些信息,人工统计的话...三天三夜吧 python 不愧是万能语言,发现有一个包叫做 docx,非常好用,具体查看官方文档:https://python-docx.read ...
- ASP 读取Word文档内容简单示例
以下通过Word.Application对象来读取Doc文档内容并显示示例. 下面进行注册Word组件:1.将以下代码存档命名为:AxWord.wsc XML code复制代码 <?xml ve ...
随机推荐
- Java 设计模式学习总结(上)
在编写和维护公司的现有代码的时候,我经常思考的问题是:怎样的系统算一个好的系统?如何设计具有扩展.可维护.复用的系统,它能最大限度的应对产品经理不断变化的需求.答案似乎是:设计模式. Remember ...
- hdu 1166 敌兵布阵(线段树单点更新,区间查询)
题意:区间和 思路:线段树 #include<iostream> #include<stdio.h> using namespace std; #define MAXN 500 ...
- 【转】linux之mkfs/mke2fs格式化
转自:http://blog.csdn.net/andyhooo/article/details/5321584 mkfs [root@www ~]# mkfs [-t 檔案系統格式] 裝置檔名 選項 ...
- APP测试时不可忽视搭建代理服务器抓包测试的必要性
这几天测的一个app,后台从已有服务器搬迁到了阿里云,接口api之类的都没有变化,但测试时发现客户端始终无法使用,每次点击都无法获得服务器反馈 用python编写脚本调接口,没问题,返回数据一切正常, ...
- 求职基础复习之冒泡排序c++版
代码中在第一层循环中增加一个bool值,是为了防止在排序完成后还继续无谓的比较,最多会有(n-1)*(n-2)/2次循环. #include<iostream> using namespa ...
- vs2013下自动注释的运用
1.首先是VAssistX,可以在VS的工具下,拓展和更新里面找到,然后下载安装即可: 以下为大家介绍一下怎么添加函数头注释:随便打开一个C++的工程,找到一个方法,右击函数名,然后依次点击“Refa ...
- servicestack操作redis
tatic void Main(string[] args) { );//redis服务IP和端口 #region =insert= var storeMembers = new List<st ...
- 10个优质PSD文件资源下载
很多设计需求并不一定要从头开始设计,你完全可以通过已有的灵感或素材开始设计任务.这个时候你可能需要一些PSD资源作为参考.今天我整理了一些常用的PSD资源供需要的朋友免费下载使用. Web & ...
- air开发中的requestedDisplayResolution 扫盲
app.xml里面requestedDisplayResolution 取值可以为high/standard, 如果为high表示设备跟ios声明它需要使用高清屏(其实就是需要最大分辨率) 这里我猜测 ...
- Bezier曲线的原理 及 二次Bezier曲线的实现
原文地址:http://blog.csdn.net/jimi36/article/details/7792103 Bezier曲线的原理 Bezier曲线是应用于二维图形的曲线.曲线由顶点和控制点组成 ...