欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

C#使用oledb读取excel表格内容到datatable的方法

程序员文章站 2022-07-01 17:03:01
本文实例讲述了c#使用oledb读取excel表格内容到datatable的方法。分享给大家供大家参考。具体分析如下: 首先看一段实例代码 复制代码 代码如下:stri...

本文实例讲述了c#使用oledb读取excel表格内容到datatable的方法。分享给大家供大家参考。具体分析如下:

首先看一段实例代码

复制代码 代码如下:
string strcon = @"provider=microsoft.ace.oledb.12.0;data source=" + excel_path + ";extended properties='excel 12.0;hdr=yes;imex=1'";
oledbconnection myconn = new oledbconnection(strcon);
string strcom = "select * from [part$a7:ak] where [part no]=10506";
myconn.open();
oledbdataadapter mycommand = new oledbdataadapter(strcom, myconn);
dataset mydataset = new dataset();
mycommand.fill(mydataset, "part");
myconn.close();

imex=1的作用是,当读取excel中每个单元格的值到datatable中的时候,不管其在excel单元格时候是什么数据类型,赋值到datatable中都强制转化为字符串类型。

在没有imex=1这个属性的时候,默认的是根据excel中对应column的数据类型来决定datatable中column的数据类型。这种情况在excel中某一列的数据类型都是一致的情况下没有问题,是什么类型,就会在datatable中的对应列设置相应的类型。但是如果excel中这一列的类型混乱的话,比如说既包括数值型又有字符串型,在运行时创建datatable的时候,会去先判断excel中这一列哪种类型的数据占主体,然后给datatable的列设置为这种类型。比如说,如果一列中既有整数型又有字符型,而整数型单元格占主体,这时datatable中的列就是整数型。

这时又出现另外一个问题,当要把值写入到datatable的时候,如果该单元格符合datatable中要求的类型,就会写入,如果不符合的话,系统会去强制转换。比如,如果excel中是字符串的5,而该单元格所在的列整数型占主体,datatable中这一列是数值型,这时,系统会把字符串的5强制转为数值型的5然后赋给datatable相应的地方。但是,此时,如果转换有问题的话,比如,此列中有一单元格中是“no5”,这时强制转换就会有问题,系统就会给datatable相应的地方赋值dbnull,现在如果你用datagridview来显示那个datatable的时候,这个地方显示出来就是一个空白的格,但要注意的是,并不是datatable中的这一行这一列是null,而是dbnull.其实,我觉得,跟null的作用是一样的,反正在datagridview中是不会显示出来。只是我们在写程序如果需要对datatable的null元素筛选的话,需要注意这个问题。

如果excel中,某一行字符串类型占主体的话,那么datatable中这一列就会设置为字符串型,而且任何类型都能顺利转换成字符串类型,所以,excel的类会完整的显示出来,不管这一列中的字符串类型的单元格,还是整数型的单元格,都能完整的显示出来。这是一很特别的地方。但这仅仅是一个特例。

所以,如果为了处理的时候数据类型的一致性,如果excel中数据类型混乱的话,可以使用imex=1使datatable中的所有列都转为字符型。

接下来说一个相关的问题,那就是datatable中使用语句进行筛选的问题这时也要注意datatable中column的类型问题。在下边的例子中,f1,f2,f3等都是datatable的列名。

下边这个例子中,f1列是数值型,f5列是字符串型

datarow[] rows = table.select("f1='1540' andf5='no2'");

这时程序不会报错,因为f1='1540',虽然筛选条件中给的是字符串类型的1540与table不符合,但是系统会自己去转换,所以这里写f1='1540'和f1=1540都是可以的。f5列是字符串型,f5='no2'也没问题。

现在我们看另外一种情况,f1列是数值型,f5列是数值型.

datarow[] rows = table.select("f1='1540' andf5='no2'");

当遇到f5='no2'后,系统会自动去转换,此时,由于不能顺利转换成数值型,在筛选到这里的时候,就会抛出异常,operator= can't perform on system.double and system.string

我们再看一种情况,f1列是数值型,f5列是字符型.

datarow[] rows = table.select("f1=1540 andf5='no2'");

这种情况也是没问题的,f1=1540,因为本身f1就是数值型,所以不必给1540加引号.

但是, 我们注意一种特殊情况 ,f1列是数值型,f5列是字符型.

datarow[] rows = table.select("f1=1540 and f5=no2');

这种情况下会报错,系统不会自动把no2转换为字符串,而是把grade2看成一个列了,系统做的判断是,这一行的这两列的单元格值相等,而datatable中又没有这个列名,所以就会抛出找不到这个列的异常。所以,当某一列为字符串类型时,一定要加上单引号,否则会有异常抛出。

希望本文所述对大家的c#程序设计有所帮助。