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. PHP命令行模式

    <?php error_reporting(E_ALL); header('Content-Type:text/plain;charset=utf-8'); interface CommandA ...

  2. 关于MyBatis mapper的insert, update, delete返回值

    这里做了比较清晰的解释: http://mybatis.github.io/mybatis-3/java-api.html SqlSession As mentioned above, the Sql ...

  3. COGS 2. 旅行计划

    2. 旅行计划 ★☆   输入文件:djs.in   输出文件:djs.out   简单对比时间限制:3 s   内存限制:128 MB 过暑假了,阿杜准备出行旅游,他已经查到了某些城市的两两之间的距 ...

  4. indows 8上强制Visual Studio以管理员身份运行

    http://diaosbook.com/Post/2013/2/28/force-visual-studio-always-run-as-admin-on-windows-8 Windows 8的一 ...

  5. C#并发编程经典实例--笔记

    一.简介   --并发         同时做多件事情 --多线程         并发的一种形式,它采用多个线程来执行程序.             **如非必要,代码里不要出现 "new ...

  6. mac系统上使用压缩包版的mysql(非安装版)

    mac本换了块固态硬盘,一切重新装过,mysql嫌官网下载太慢,直接百度 "mysql mac",第一个就是: 不料下载完后,发现这是一个压缩包版,并没有安装程序.网上搜索了一下, ...

  7. Wcf:可配置的服务调用方式

    添加wcf服务引用时,vs.net本来就会帮我们在app.config/web.config里生成各种配置,这没啥好研究的,但本文谈到的配置并不是这个.先看下面的图: 通常,如果采用.NET的WCF技 ...

  8. ICSharpCode.SharpZipLib

    ICSharpCode.SharpZipLib 压缩.解压文件 附源码   http://www.icsharpcode.net/opensource/sharpziplib/ 有SharpZipli ...

  9. DOM 元素节点几何量与滚动几何量

    当在 Web 浏览器中查看 HTML 文档时,DOM 节点被解析,并被渲染成盒模型(如下图),有时我们需要知道一些信息,比如盒模型的大小,盒模型在浏览器中的位置等等,本文我们就来详细了解下元素节点的几 ...

  10. 备忘:hibernate, logback, slf4j实际应用一例

    用hibernate写一些简单的数据库的Java应用.主要是温习一下.之前弄过的一些都忘了.发现还是得记下来,不然很快就忘. 1. Eclipse版本,用Juno, J2EE版本.最好下载zip版本的 ...