Provider根据实际EXCEL的版本来设置,推荐使用ACE接口来读取。需要Access database Engine。

注意修改注册表以下两项的值为0。否则导入EXCEL当单元格内字符长度超过255会发生截断现象!!!

HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Office\12.0\AccessConnectivity Engine\Engines\Excel\TypeGuessRows

64位系统下

HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Microsoft\Office\12.0\Access Connectivity Engine\Engines\Excel\ TypeGuessRows

看到论坛里面不断有人提问关于读取excel和导入excel的相关问题。闲暇时间将我所知道的对excel的操作加以总结,现在共享大家,希望给大家能够给大家带了一定的帮助。
另外我们还要注意一些简单的问题1.excel文件只能存储65535行数据,如果你的数据大于65535行,那么就需要将excel分割存放了。2.关于乱码,这主要是字符设置问题。

1.加载Excel(读取excel内容)返回值是一个DataSet

  1. //加载Excel
  2. public static DataSet LoadDataFromExcel(string filePath)
  3. {
  4. try
  5. {
  6. string strConn;
  7. strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + filePath + ";Extended Properties='Excel 8.0;HDR=False;IMEX=1'";
  8. OleDbConnection OleConn = new OleDbConnection(strConn);
  9. OleConn.Open();
  10. String sql = "SELECT * FROM  [Sheet1$]";//可是更改Sheet名称,比如sheet2,等等
  11. OleDbDataAdapter OleDaExcel = new OleDbDataAdapter(sql, OleConn);
  12. DataSet OleDsExcle = new DataSet();
  13. OleDaExcel.Fill(OleDsExcle, "Sheet1");
  14. OleConn.Close();
  15. return OleDsExcle;
  16. }
  17. catch (Exception err)
  18. {
  19. MessageBox.Show("数据绑定Excel失败!失败原因:" + err.Message, "提示信息",
  20. MessageBoxButtons.OK, MessageBoxIcon.Information);
  21. return null;
  22. }
  23. }

2.写入Excel内容,参数:excelTable是要导入excel的一个table表

    1. public static bool SaveDataTableToExcel(System.Data.DataTable excelTable, string filePath)
    2. {
    3. Microsoft.Office.Interop.Excel.Application app =
    4. new Microsoft.Office.Interop.Excel.ApplicationClass();
    5. try
    6. {
    7. app.Visible = false;
    8. Workbook wBook = app.Workbooks.Add(true);
    9. Worksheet wSheet = wBook.Worksheets[1] as Worksheet;
    10. if (excelTable.Rows.Count > 0)
    11. {
    12. int row = 0;
    13. row = excelTable.Rows.Count;
    14. int col = excelTable.Columns.Count;
    15. for (int i = 0; i < row; i++)
    16. {
    17. for (int j = 0; j < col; j++)
    18. {
    19. string str = excelTable.Rows[i][j].ToString();
    20. wSheet.Cells[i + 2, j + 1] = str;
    21. }
    22. }
    23. }
    24. int size = excelTable.Columns.Count;
    25. for (int i = 0; i < size; i++)
    26. {
    27. wSheet.Cells[1, 1 + i] = excelTable.Columns[i].ColumnName;
    28. }
    29. //设置禁止弹出保存和覆盖的询问提示框
    30. app.DisplayAlerts = false;
    31. app.AlertBeforeOverwriting = false;
    32. //保存工作簿
    33. wBook.Save();
    34. //保存excel文件
    35. app.Save(filePath);
    36. app.SaveWorkspace(filePath);
    37. app.Quit();
    38. app = null;
    39. return true;
    40. }
    41. catch (Exception err)
    42. {
    43. MessageBox.Show("导出Excel出错!错误原因:" + err.Message, "提示信息",
    44. MessageBoxButtons.OK, MessageBoxIcon.Information);
    45. return false;
    46. }
    47. finally
    48. {
    49. }
    50. }

c#读取excel的更多相关文章

  1. java的poi技术读取Excel数据到MySQL

    这篇blog是介绍java中的poi技术读取Excel数据,然后保存到MySQL数据中. 你也可以在 : java的poi技术读取和导入Excel了解到写入Excel的方法信息 使用JXL技术可以在 ...

  2. poi读取excel模板,填充内容并导出,支持导出2007支持公式自动计算

    /** * 版权所有(C) 2016 * @author www.xiongge.club * @date 2016-12-7 上午10:03:29 */ package xlsx; /** * @C ...

  3. C#读取Excel,或者多个excel表,返回dataset

    把excel 表作为一个数据源进行读取 /// <summary> /// 读取Excel单个Sheet /// </summary> /// <param name=& ...

  4. PHP读取EXCEL时间

    在使用php读取excel表格中的时间时得到一串数字而不是时间:40359.58333333334 excel 中的时间值是自1900年以来的天数,注意是格林威治时间php 中的时间值是自1970年以 ...

  5. Open Xml 读取Excel中的图片

      在我的一个项目中,需要分析客户提供的Excel, 读出其中的图片信息(显示在Excel的第几行,第几列,以及图片本身). 网络上有许多使用Open Xml插入图片到Word,Excel的文章, 但 ...

  6. 使用Open xml 操作Excel系列之一-读取Excel

    一. 安装Open Xml SDK 从微软网站下载Open xml SDK,安装SDK. 二. 在项目中添加对DocumentFormat.OpenXml库的引用

  7. 使用NPOI读取Excel报错ICSharpCode.SharpZipLib.Zip.ZipException:Wrong Local header signature

    写了一个小程序利用NPOI来读取Excel,弹出这样的报错: ICSharpCode.SharpZipLib.Zip.ZipException:Wrong Local header signature ...

  8. C#读取Excel设置(亲测可用)

    OpenFileDialog openFD = new OpenFileDialog(); openFD.FileName = ""; openFD.Filter = " ...

  9. 使用Aspose.Cells读取Excel

      最新更新请访问: http://denghejun.github.io Aspose.Cells读取Excel非常方便,以下是一个简单的实现读取和导出Excel的操作类: 以下是Aspose.Ce ...

  10. 使用LinqToExcel读取Excel

    我们读取和写入Excel 经常使用NPOI工具,如果我们的需求只是需要读取Excel,可以考虑使用LinqToExcel这个组件.这个组件用起来简单,实用,操作方便,而且结合了Linq的查询特性,ex ...

随机推荐

  1. sql server 修改表结构语法大全

    1.增加字段 ) 2.删除字段 alter table table_name drop column column_name 3.修改字段类型 alter table table_name alter ...

  2. gitlab配置邮件通知功能操作记录

    之前已经介绍了gitlab的部署http://www.cnblogs.com/kevingrace/p/5651402.html但是没有配置邮箱通知功能,今天这里介绍下gitlab安装后的邮箱配置操作 ...

  3. 全面解读python web 程序的9种部署方式

    转载自鲁塔弗的博客,本文地址http://lutaf.com/141.htm  python有很多web 开发框架,代码写完了,部署上线是个大事,通常来说,web应用一般是三层结构 web serve ...

  4. 在ESXi 5.x之间冷迁移虚机

    试过几种不同的方法都不成功, 直接用VMware vCenter Converter Standalone Client迁移, 会出现task中的source与job中的source不一致的情况, 使 ...

  5. http://www.cnblogs.com/figure9/p/developer-reading-list.html

    http://www.cnblogs.com/figure9/p/developer-reading-list.html

  6. Spring的反射机制和依赖注入

    我们知道,Spring中大量使用了反射机制,那么究竟是什么地方使用了呢? spring的一大核心概念是注入, 但是,这存在的一个前提就是类是由spring管理起来的. 反射是根据className生成 ...

  7. C#.NET 大型通用信息化系统集成快速开发平台 4.0 版本 - 省市区数据权限的实现效果

    折腾了2-3周,终于把全国网点数据权限,省.市.县数据规范化,查询权限规范化,基础数据规范化的思路理清楚了, 今天应该是一个里程碑式的一天 省市区数据规范化后 1:网点的基础数据可以更加严谨规范化. ...

  8. shell 脚本替换文件中某个字符串

    1.将当前目录下包含jack串的文件中,jack字符串替换为tom sed -i "s/jack/tom/g" `grep "jack" -rl ./` 2.将 ...

  9. &11,散列表

    #1,是什么? 散列表(Hash table,也叫哈希表),是根据关键码值(Key value)而直接进行访问的数据结构.也就是说,它通过把关键码值映射到表中一个位置来访问记录,以加快查找的速度.这个 ...

  10. Theano2.1.15-基础知识之theano如何处理shapre信息

    来自:http://deeplearning.net/software/theano/tutorial/shape_info.html How Shape Information is Handled ...