:DataTableImportSheet(FileName,SheetSource,SheetDest) DataTableExportSheet(FileName,DTSheet) 用上述的方法,在脚本中导入导出excel中的数据。对应的是文件名,文件路径,还有excel的sheet名。
1首先看一段实例代码
2IMEX=1的作用是,当读取Excel中每个单元格的值到DataTable中的时候,不管其在Excel单元格时候是什么数据类型,赋值到DataTable中都强制转化为字符串类型。
3在没有IMEX=1这个属性的时候,默认的是根据Excel中对应Column的数据类型来决定DataTable中Column的数据类型。这种情况在Excel中某一列的数据类型都是一致的情况下没有问题,是什么类型,就会在DataTable中的对应列设置相应的类型。但是如果Excel中这一列的类型混乱的话,比如说既包括数值型又有字符串型,在运行时创建DataTable的时候,从Excel中前8行进行采样分析,会去先判断Excel中这一列哪种类型的数据占主体,然后给DataTable的列设置为这种类型。比如说,如果一列中既有整数型又有字符型,而整数型单元格占主体,这时DataTable中的列就是整数型。
4这时又出现另外一个问题,当要把值写入到DataTable的时候,如果该单元格符合DataTable中要求的类型,就会写入,如果不符合的话,系统会去强制转换。比如,如果Excel中是字符串的5,而该单元格所在的列整数型占主体,DataTable中这一列是数值型,这时,系统会把字符串的5强制转为数值型的5然后赋给DataTable相应的地方。但是,此时,如果转换有问题的话,比如,此列中有一单元格中是“NO5”,这时强制转换就会有问题,系统就会给DataTable相应的地方赋值DBNull,现在如果你用DataGridView来显示那个DataTable的时候,这个地方显示出来就是一个空白的格,但要注意的是,并不是DataTable中的这一行这一列是null,而是DBNull其实,我觉得,跟null的作用是一样的,反正在DataGridView中是不会显示出来。只是我们在写程序如果需要对DataTable的null元素筛选的话,需要注意这个问题。
5如果Excel中,某一行字符串类型占主体的话,那么DataTable中这一列就会设置为字符串型,而且任何类型都能顺利转换成字符串类型,所以,Excel的类会完整的显示出来,不管这一列中的字符串类型的单元格,还是整数型的单元格,都能完整的显示出来。这是一很特别的地方。但这仅仅是一个特例。
6所以,如果为了处理的时候数据类型的一致性,如果Excel中数据类型混乱的话,可以使用IMEX=1使DataTable中的所有列都转为字符型。这种设置并不可靠,IMEX=1只确保在某列前8行数据至少有一个是文本项的时候才起作用,它只是把查找前8行数据中数据类型占优选择的行为作了略微的改变。例如某列前8行数据全为纯数字,那么它仍然以数字类型作为该列的数据类型(详细解释见下面的补充说明)
7接下来说一个相关的问题,那就是DataTable中使用语句进行筛选的问题这时也要注意DataTable中Column的类型问题。在下边的例子中,F1,F2,F3等都是DataTable的列名。
下边这个例子中,F1列是数值型,F5列是字符串型
当遇到F5='NO2'后,系统会自动去转换,此时,由于不能顺利转换成数值型,在筛选到这里的时候,就会抛出异常,Operator= can’t perform on SystemDouble and SystemString
再看一种情况,F1列是数值型,F5列是字符型
这种情况也是没问题的,F1=1540,因为本身F1就是数值型,所以不必给1540加引号
但是,注意一种特殊情况 ,F1列是数值型,F5列是字符型
这种情况下会报错,系统不会自动把NO2转换为字符串,而是把Grade2看成一个列了,系统做的判断是,这一行的这两列的单元格值相等,而DataTable中又没有这个列名,所以就会抛出找不到这个列的异常。所以,当某一列为字符串类型时,一定要加上单引号,否则会有异常抛出。
方法: 比如你的datatable为T column c=TCloumes['列名']; c就是你相要的东西,如果它只有一个值的话,可以是: 类型 c=TCloumes['列名']rows[0]Value; 对datatable里面的表进行排序: 一、重生法 dstasetTablesAdd(dt) datasetTables(0)DefaultViewSort = "id desc" 二、直接法 dv = New DataView(dt) dvSort = "id desc
代码如下:
private void button1_Click(object sender, EventArgs e)
{
//假定目前dataset里只有一个表
DataTable dt = dsTables[0];
string textname = "tn";//必须保证有这行
DataRow dr = dtSelect("text='{0}'", textname)[0];
string suibe = dr[2]ToString();
//或者
string suibe1 = dr["suibe"]ToString();
//现在是给textbox赋值
//其他列类似 *** 作
}
扩展资料
DataSet用法详细
一、特点介绍
1、处理脱机数据,在多层应用程序中很有用。
2、可以在任何时候查看DataSet中任意行的内容,允许修改查询结果的方法。
3、处理分级数据
4、缓存更改
5、XML的完整性:DataSet对象和XML文档几乎是可互换的。
二、使用介绍
1、创建DataSet对象:
DataSetds = new DataSet("DataSetName");
2、查看调用SqlDataAdapterFill创建的结构
daFill(ds,"Orders");
DataTabletbl = dsTable[0];
foreach(DataColumncol in tblColumns)
ConsoleWriteLine(colColumnName);
1、dataSet是一个数据集合,dataSetTables是一个存放DataTable的数组,当adapterFill(dataSet);执行后,程序会通过SQL引擎返回一个结果集存放在内存中,这个结果集就是一个DataTable,并且这个DataTable会被添家到dataSetTables中,所以return dataSetTables[0],就是返回你所要查询的结果集2、string rid = tableRows[0]["rid"]ToString(); //tableRows[0]表示table的第一行数据,tableRows[0]["rid"]ToString()表示table中列rid的值,table的所有列是你在SQL中所查询的所有列
比如你的datatable为T
column c=TCloumes['列名'];
c就是你相要的东西,如果它只有一个值的话,可以是:
类型 c=TCloumes['列名']rows[0]Value;
以上就是关于excel data table 在哪全部的内容,包括:excel data table 在哪、如何通过OleDb取excel特定列的值、DataTable.Columns怎样取值等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)