原文地址:http://www.open-open.com/code/view/1420029490093

public DataTable ExcelToDS(string Path)
{
string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + Path + ";" + "Extended Properties=Excel 8.0;";
OleDbConnection conn = new OleDbConnection(strConn);
conn.Open();
DataTable schemaTable = conn.GetOleDbSchemaTable(System.Data.OleDb.OleDbSchemaGuid.Tables, null);
string strTable = "";
if (schemaTable.Rows.Count > )
{
strTable = schemaTable.Rows[]["TABLE_NAME"].ToString();
}
string strExcel = "";
OleDbDataAdapter myCommand = null;
DataSet ds = null;
strExcel = "select * from [" + strTable + "]";
myCommand = new OleDbDataAdapter(strExcel, strConn);
ds = new DataSet();
myCommand.Fill(ds, "table1");
conn.Close();
return ds.Tables[];
}
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
string strFilePath = Server.MapPath("~") + "upload\\bool.xls";
ExcelToDS(strFilePath);
}
}

在导出Excel的过程中,有可能出现的问题:OleDbConnection.open() 外部表不是预期的格式

解决方案1:

很多人换了2010后,问的最多的问题之一是2003里最经典的ADO中的“provider=Microsoft.Jet.OLEDB.4.0”这句怎么不能用了。

百度一下可以了解到,Microsoft.Jet.OLEDB.4.0是Microsoft Jet引擎,这适用于2003版本(2003之前的我没装,所以也不知道能向下适应到哪个版本),而在2007中,微软对其旗下 Access 与 Excel 的主要文件格式进行修改,并且重命名为 .accdb(Access 2007 数据库文件)与 .xlsx(Excel 2007 文件),因此未被 Microsoft Jet 引擎所支持,不过微软也很快的提出了Microsoft Office 2007 Desktop Drivers: Data Connectivity Components 来支持,目前的解决方法就是把连接字符串中的数据提供者改为Microsoft.ACE.OLEDB.12.0

总上所述:

//2003(Microsoft.Jet.Oledb.4.0)
string strConn = string.Format("Provider=Microsoft.Jet.OLEDB.4.0;Data Source={0};Extended Properties='Excel 8.0;HDR=Yes;IMEX=1;'", excelFilePath);

//2010(Microsoft.ACE.OLEDB.12.0)
string strConn = string.Format("Provider=Microsoft.ACE.OLEDB.12.0;Data Source={0};Extended Properties='Excel 8.0;HDR=Yes;IMEX=1;'", excelFilePath);

解决方案2:
用记事本打开你的excel文件,看看显示是否为乱码。
若是乱码,我这边测试是不会提示这个错误的,可以成功导入。
若是html代码,则表示你的excel文件格式不是标准的excel格式,才会提示“外部表不是预期的格式”的错误;
总结:如果格式不正确,则通过excel软件另存为标准的2003版本的格式

最新文章

  1. sqlmap 技巧整理
  2. windows下远程连接ubantu
  3. mysql 无法远程访问(授权也没办法,确切的说是因为只绑定了127IP)
  4. leetcode 91 Decode Ways ----- java
  5. android中handler中 obtainmessge与New message区别
  6. Invalid segment BIN$xxx and dba_recyclebin was empty (回收站空,释放无效的BIN$xx空间)
  7. 转载:Ununtu下中文乱码解决方案
  8. AJAX及其跨域的主要解决方法
  9. sbt公布assembly解决jar包冲突 deduplicate: different file contents found in the following
  10. HDU 5008 求第k小子串
  11. 部署腾讯云(CentOS6.6版本,jdk1.7+tomcat8+mysql)
  12. spiral matrix 螺旋矩阵
  13. 首次安装Ubuntu
  14. Django:安装和启动
  15. poj1436水平可见线
  16. 037 对于HIVE架构的理解
  17. 虚拟机中在centos6.7环境下安装eclipse
  18. 洛谷P1177快速排序
  19. UVALive 4869 Profits DP
  20. fileupload的乱码解决

热门文章

  1. django-xadmin使用
  2. homebrew学习(四)之取消homebrew自动更新
  3. 修改jar包package目录结构操作方法
  4. MySQL之常用SQL语句
  5. mongoose 开源http库(2) --HTTP服务示例
  6. linux 生成密钥和公钥,实现免密登录
  7. 【洛谷P1220】关路灯
  8. 通信接口是webservice快还是scoket快解决方案
  9. Quartz--Spring 定时任务
  10. Olympic Game