我的excel是2003版本的,里边有sheet1、sheet2两个工作表,当使用GetOleDbSchemaTable获取表Schema时,结果是4个,分别为: sheet1 sheet1$ sheet2 sheet2$
原帖地址:http://bbs.csdn.net/topics/310230098
-----------------------------------------------------------------------------------------------------
我的excel是2003版本的,里边有sheet1、sheet2两个工作表,当使用GetOleDbSchemaTable获取表Schema时,结果是4个,分别为:
sheet1 sheet1$ sheet2 sheet2$
代码如下
string cnnString = string.Format("Provider=Microsoft.Jet.OleDb.4.0;Data Source={0};Extended Properties='Excel 8.0;HDR=yes; IMEX=2;'", sourceFile);
OleDbConnection cnn=new OleDbConnection(destCnnString);
cnn.Open ();
DataTable dtSchema = cnn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new object[] { null, null, null, "TABLE" });
为什么呢?
-----------------------------------------------------------------------------------------------------
应该是你删除掉的那几个,我不明白为什么删除后通过你这样的方式还能看到
即如果你建立了4个sheets删除两个,但是会发现还是能找到四个
-----------------------------------------------------------------------------------------------------
奇怪了!如果删除sheet1$,那么sheet1也就不见了!如果我新建一个sheet,那么就不会多一个sheet出来!查看隐藏的sheet也没有发现,为什么会多sheet出来呢?这个excel是别人给的,如果我自己建立excel文件则是正常的,为什么呢?
-----------------------------------------------------------------------------------------------------
又发现一个问题,如果是用dts导出来的,那就会有两个表名,如customers$和customers,不知道为什么?
-----------------------------------------------------------------------------------------------------
确定问题所在了!
1:GetOleDbSchemaTable取到的表的信息还包括excel的命名区域;
2:因为excel是通过dts导出生成的,导出时同时生成了命名区域;(还没找到哪里可以设置不生成命名区域)
3:在excel2007中,公式--命名管理器中,删除命名区域即可!
我的excel是2003版本的,里边有sheet1、sheet2两个工作表,当使用GetOleDbSchemaTable获取表Schema时,结果是4个,分别为: sheet1 sheet1$ sheet2 sheet2$的更多相关文章
- 通用的C#导出Excel  支持2003及2007以上版本
		
将数据导出到Excel,供用户下载是经常要使用到的一个功能,我这里进行了一些封装,目前已满足项目中导出的需求,使用DataReader导出Excel,支持自定义多表头,使用委托处理字段格式化及字段值的 ...
 - 个人永久性免费-Excel催化剂功能第51波-聚光灯功能,长宽工作表不看错位使用
		
Excel的聚光灯功能,笔者是有点看不上,也曾经写文吐槽过这些类似的功能的实用性,但现实可能真的很多小白很需要,大家Excel水平参差不齐,大量的不规范做表习惯,致使此功能使用场景仍然非常广阔.很怀疑 ...
 - vlookup函数基本使用--如何将两个Excel表中的数据匹配;excel表中vlookup函数使用方法将一表引到另一表
		
vlookup函数基本使用--如何将两个Excel表中的数据匹配:excel表中vlookup函数使用方法将一表引到另一表 一.将几个学生的籍贯匹配出来‘ 二.使用查找与引用函数 vlookup 三. ...
 - python openpyxl模块实现excel的读取,新表创建及原数据表追加新数据
		
当实际工作需要把excel表的数据读取出来,或者把一些统计数据写入excel表中时,一个设计丰富,文档便于寻找的模块就会显得特别的有吸引力,本文对openpyxl模块的一些常见用法做一些记录,方便工作 ...
 - excel怎么并排查看两个工作表
		
excel怎么并排查看两个工作表 excel怎么并排查看两个工作表?excel打开一个窗口想要同时查看两个工作表中的数据,类似于word中的分栏效果,该怎么实现呢?EXCEL是一个使用最多的办公软件, ...
 - java POI读取excel 2007/2003
		
2003版office excel读取 import java.io.FileNotFoundException; import java.io.IOException; import java.io ...
 - poi 导入Excel解析 2003 2007
		
Workbook wb = WorkbookFactory.create(new FileInputStream(file)); Sheet sheet = wb.getSheetAt(0);// 第 ...
 - 读取Excel文件的版本
		
读取xls文件和xlsx文件创建的版本号. 虽然xlsx声明的是向前兼容,但是不知道OleDb是不是也是这样,没有办法所以要读取文件版本,限定只能读取Excel2007保存的文件. using ICS ...
 - 不使用模板导出Excel(C#版本)
		
不多说,直接上干货! using System; using System.Collections.Generic; using System.Linq; using System.Web; usin ...
 
随机推荐
- Python logging 模块打印异常 exception
			
logger.exception(sys.exc_info())
 - mac OS 安装 nvm
			
nvm官网 https://github.com/creationix/nvm nvm,node,npm之间的区别 nvm:nodejs 版本管理工具 一个 nvm 可以管理很多 node 版本和 n ...
 - 家用PC机打造VSphere5.1 测试环境:之部署VCenter Server 5.1
			
家用PC机打造VSphere5.1 测试环境前言:实践出真知,同样学习VMware VSphere 的朋友,也需要不断的测试总结,再测试再总结只有不断的积累才能学好,但是动辄几万的服务器不是所有朋友都 ...
 - Blockchain
			
一.中心化 中心化原则是我们日常比较常见的支付手段. 科普文章喜欢用网购举例: 1.你在某宝支付了一件商品,钱先到马云爸爸手中,通知商家发货: 2.商家发货,你收货后确认无误,点击确认收货: 3.马云 ...
 - CF思维联系–CodeForces-217C C. Formurosa(这题鸽了)
			
ACM思维题训练集合 The Bytelandian Institute for Biological Research (BIBR) is investigating the properties ...
 - LeetCode 56,区间合并问题
			
本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是LeetCode专题的第33篇文章,我们一起来看LeetCode的第56题,它的难度是Medium. 题意 这道题的题意也很简单,只有 ...
 - python的unittest框架中的assert断言
			
unittest框架自带断言,如果想用assert断言,一定要引入unittest.TestCase框架才行,不然不会自动识别assert断言
 - 开源 一套 Blazor Server 端精致套件
			
Blazor 作为一种 Web 开发的新技术已经发展有一段时间了,有些人标称 无 JS 无 TS,我觉得有点误导新人的意味,也有人文章大肆宣传 Blazor 是 JavaScript 的终结者,是为了 ...
 - php扩展开发之hello world
			
最近在公司做的事情就是php扩展开发,虽然我只负责c++代码的编写,但是了解扩展开发的流程还是很有必要的. (本文介绍的是动态扩展,对静态扩展有兴趣的读者可自行google) php扩展开发环境搭建可 ...
 - 去 HBase,Kylin on Parquet 性能表现如何?
			
Kylin on HBase 方案经过长时间的发展已经比较成熟,但也存在着局限性,因此,Kyligence 推出了 Kylin on Parquet 方案(了解详情戳此处).通过标准数据集测试,与仍采 ...