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. 阿里云日志api创建logStore

    , shardCount =  });                 string date = FormatRfc822Date(time);                 string con ...

  2. ubuntu14.04安装sipp3.2

    本来在centos里不好装的软件,往往ubuntu里会很好装,但sipp恰恰相反,ubuntu里能装死你. 做VOIP测试的话,有时候为了模拟通话中更好的抓包,在环境简陋,又不想使用集线器引起广播风暴 ...

  3. JS常用自定义方法

    1,JS生成随机数方法 getRandom(100),表示生成0-100的数 function getRandom(n){ return Math.floor(Math.random()*n+1) } ...

  4. Markdown:认识&入门

    来源:http://sspai.com/25137 一.认识 Markdown 在刚才的导语里提到,Markdown 是一种用来写作的轻量级「标记语言」,它用简洁的语法代替排版,而不像一般我们用的字处 ...

  5. Linux commands frequently used

    touch <filename>.sh gedit <filename>.sh bash <filename>.sh & ps auxw|grep < ...

  6. vs2013怎么打开vs2010的解决方案

    1.直接用vs2013打开解决方案的sln文件,vs会自动进行转换的2.或者你用记事本的方式打开sln文件 将版本号改一下Microsoft Visual Studio Solution File, ...

  7. 折腾了1周把程序从sqlserver迁移到oracle上了,每折腾一次需要耗费1周时间

    主要花费时间的事情: 1:安装配套的服务器,安装操作系统,安装数据库,配置远程访问等等,一般会耗费1天时间,甚至2天时间,若手头安装盘不齐全,需要耗费更多时间. 2:远程传输安装文件.特别是开发环境等 ...

  8. 单页面网站关于id冲突的解决办法

    最近做了一个单页面的网站,所有的页面加载都是通过局部刷新的方式,并且不用iframe,并且我们引入了动态tab页签: 所有的页签里的内容都只是一个元素,都在同一个html页面上,没有任何iframe分 ...

  9. java 客户端链接不上redis解决方案

    原文地址:http://blog.csdn.net/yingxiake/article/details/51472810 出现问题描述: 1.Could not get a resource from ...

  10. TM4C123G红外触摸屏:开发板好不容易实现了原理,放到专家设计的板子上无法运行,于是专家跑路项目黄了

    使用TI的TM4C123G LaunchPad开发板,USB接口,来对同样的芯片进行烧写. 我们只用烧写那一块功能,不用另外一个芯片的开发功能,需要跳线   源码项目:   从官方网站TM4C123G ...