本方法,将传入的Excel文件内所有的Sheet内的数据都填充入DataSet中。这是一个简单快捷的方法,不足之处是不适合带有格式复杂的Excel文件。(比如:有合并单元格的)

  1. public class ExcelUtil
  2. {
  3. /// <summary>
  4. /// 从Excel文件导入DataSet
  5. /// Excel的连接字符串说明(详细参看 http://www.connectionstrings.com/excel ):
  6. /// HDR=Yes 表示第一行是表头,没有数据,读取时忽略第一行。设置为 No 时则从第一行读取。
  7. /// IMEX=1  表示告诉OleDb驱动,所有数据将作为字符串读取(numbers,dates等)
  8. /// 注意:有时候因为ISAM驱动没有安装,设置HDR和IMEX会出异常。去掉即可。
  9. /// </summary>
  10. /// <param name="fileName">Excel文件路径</param>
  11. /// <param name="firstRowIsHeader">第一行是否是表头</param>
  12. /// <returns>Excel数据,一个Sheet对应一个DataTable</returns>
  13. public static DataSet GetDataSetFromExcel(string fileName, string sheetName = "", bool firstRowIsHeader = true)
  14. {
  15. if (!System.IO.File.Exists(fileName))
  16. throw new ArgumentException("file is not exist!");
  17. var ds = new DataSet();
  18. var strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source='{0}';Extended Properties=Excel 8.0;";
  19. //if (firstRowIsHeader)
  20. //    strConn += "HDR=Yes;";
  21. strConn = string.Format(strConn, fileName);
  22. using (var conn = new OleDbConnection(strConn))
  23. {
  24. conn.Open();
  25. DataTable excelSchema = null;
  26. string sql = "select * from [{0}]";
  27. var adapter = new OleDbDataAdapter();
  28. adapter.SelectCommand = conn.CreateCommand();
  29. if (string.IsNullOrEmpty(sheetName))
  30. {
  31. excelSchema = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables,
  32. new object[] { null, null, null, "TABLE" });
  33. foreach (DataRow row in excelSchema.Rows)
  34. {
  35. var sheet = row["TABLE_NAME"].ToString();
  36. sql = string.Format(sql, sheet);
  37. adapter.SelectCommand.CommandText = sql;
  38. adapter.Fill(ds, sheet);
  39. }
  40. }
  41. else
  42. {
  43. sql = string.Format(sql, sheetName + "{1}quot;);
  44. adapter.SelectCommand.CommandText = sql;
  45. adapter.Fill(ds, sheetName);
  46. }
  47. conn.Close();
  48. }
  49. return ds;
  50. }
  51. }

上面代码中46行的 "quot;" 应为 "$" 

Excel查询的时候,加上范围也可以。这样就能指定范围获得数据。比如: 
(1) string sql = "select * from [{0}A:C]";
(2) string sql = "select * from [{0}A1:C100]";

使用:

  1. private void btnExcel2Data_Click(object sender, EventArgs e)
  2. {
  3. openFileDialog1.Filter = "Excel Files | *.xls";
  4. var ret = openFileDialog1.ShowDialog();
  5. if (ret == System.Windows.Forms.DialogResult.OK)
  6. {
  7. DataSet ds = GetDataSetFromExcel(openFileDialog1.FileName, false);
  8. this.dataGridView1.DataSource = ds.Tables[0];
  9. }
  10. }

[zz]使用OleDb,将Excel导入DataSet的更多相关文章

  1. Excel导入导出帮助类

    /// <summary>    /// Excel导入导出帮助类    /// 记得引入 NPOI    /// 下载地址   http://npoi.codeplex.com/rele ...

  2. C# 导入Excel到DataSet中

    class Import { /// <summary> /// 导入Excel到DataSet中 /// </summary> /// <param name=&quo ...

  3. EXCEL数据导入dataset

    一.开工必备 1.micorosoft office2007 2.VS2010.Oracle 11 二.界面 三.内部代码 (1)获取数据库连接,定义全局变量 private static strin ...

  4. 导入本地Excel到DataSet中

    /// <summary> /// 导入本地Excel到DataSet中 /// </summary> /// <param name="strFileSour ...

  5. (转)高效的将excel导入sqlserver中

    大部分人都知道用oledb来读取数据到dataset,但是读取之后怎么处理dataset就千奇百怪了.很多人通过循环来拼接sql,这样做不但容易出错而且效率低下,System.Data.SqlClie ...

  6. Excel 导入到Datatable 中,再使用常规方法写入数据库

    首先呢?要看你的电脑的office版本,我的是office 2013 .为了使用oledb程序,需要安装一个引擎.名字为AccessDatabaseEngine.exe.这里不过多介绍了哦.它的数据库 ...

  7. C#实现Excel模板导出和从Excel导入数据

    午休时间写了一个Demo关于Excel导入导出的简单练习 1.窗体 2.引用office命名空间 添加引用-程序集-扩展-Microsoft.Office.Interop.Excel 3.封装的Exc ...

  8. ASP.NET 将Excel导入数据库

    将Excel导入数据库大致流程:  Excel数据->DataSet->数据库 需要做的准备:1.FileUpload控件一个,按钮一个,如果需要即时显示那么GridView或DataGr ...

  9. 使用OLEDB读取excel和csv文件

    这是我第一次在博客上写东西,简单的为大家分享一个oledb读取文件的功能吧,这两天在做一个文件导入数据库的小demo,就想着导入前先在页面上展示一下,之前调用Microsoft.Office.Inte ...

随机推荐

  1. C#中的类型相等与恒等(Equality & Identity)

    l  Equality:如果两个对象是相同的类型,并且它们各自带有相同和等值的属性.(They are instances of the same type and if each of the fi ...

  2. 【索引】位图BitMap索引

    位图(BitMap)索引 前段时间听同事分享,偶尔讲起Oracle数据库的位图索引,顿时大感兴趣.说来惭愧,在这之前对位图索引一无所知,因此趁此机会写篇博文介绍下位图索引. 1. 案例 有张表名为ta ...

  3. css定位的理解

    在CSS中关于定位的内容是:position:relative | absolute | static | fixed ● static 没有特别的设定,遵循基本的定位规定,不能通过z-index进行 ...

  4. Android_开发片段(Part 2)

    1.List和Map知识: 1)如何定义 List<Map<String,Object>> list=new ArrayList<Map<String,Object ...

  5. ubuntu终端仿真程序和文件管理程序

    1.SecureCRT是一款支持SSH(SSH1和SSH2)的终端仿真程序,简单的说是Windows下登录UNIX或Linux服务器主机的软件.可以理解为ubuntu下的Terminal. 如果Sec ...

  6. Linux知识总结(更新中)

    Linux知识总结(更新中) 如何查找特定的文件 find find path [options] params 作用:在指定目录下查找文件 检索文件内容 grep grep [options] pa ...

  7. diji模板

    void diji(int x){ fill(dis,dis+n,INT_MAX); dis[x] = ; ;i < n;i++) pre[i] = i; ){ int minn = INT_M ...

  8. checkbox、radio使用jquery改变状态以及其他操作

    $('input[type=checkbox]:checked').each(function(index,elem){ $(elem).attr("checked",false) ...

  9. prototype.原型链.原型链图

      //1.几乎所有函数都有prototype属性,这个是个指针,指向原型对象;Function.prototype这个没有 //2.所有对象中都有__proto__属性.(Object.protot ...

  10. HTML a标签文字颜色

    1.css代码: a{color:#00F} a:hover{color:#f00}/* 鼠标经过悬停字体颜色 */ /* css 注释说明:以上代码为设置HTML中超链接统一字体颜色 */ .div ...