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. zlog学习笔记(zc_hashtable)

    zc_hashtable.h /** * hashtable */ #ifndef __zc_hashtable_h #define __zc_hashtable_h typedef struct z ...

  2. PAT 1009. 说反话 (20)

    给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出. 输入格式:测试输入包含一个测试用例,在一行内给出总长度不超过80的字符串.字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区 ...

  3. DirectoryBrowserMiddleware中间件如何呈现目录结构

    DirectoryBrowserMiddleware中间件如何呈现目录结构 和StaticFileMiddleware中间件一样,DirectoryBrowserMiddleware中间本质上还是定义 ...

  4. 学习C++.Primer.Plus 8 函数探幽

    1. 内联函数 普通函数调用: 存储调用指令的地址->将函数参数复制到堆栈->跳到函数地址执行代码(返回值放到寄存器)->跳回调用指令处 2.  当代码执行时间很短,且会被大量调用的 ...

  5. JAVA CDI 学习(5) - 如何向RESTFul Service中注入EJB实例

    RESTFul Service中如果要注入EJB实例,常规的@Inject将不起作用,在Jboss中,应用甚至都启动不起来(因为@Inject注入失败),解决方法很简单:将@Inject换成@EJB ...

  6. 我在 CSDN 的小窝

    以后有文章,我会同时更新 博客园 和 CSDN. CSDN:http://blog.csdn.net/u010918003

  7. 似魔鬼的 『 document.write 』

    在平时的工作中,楼主很少用 document.write 方法,一直觉得 document.write 是个危险的方法.楼主不用,并不代表别人不用,最近给维护的项目添了一点代码,更加深了我对 &quo ...

  8. CI(CodeIgniter)框架入门教程——第二课 初始MVC

    本文转载自:http://www.softeng.cn/?p=53 今天的主要内容是,使用CodeIgniter框架完整的MVC内容来做一个简单的计算器,通过这个计算器,让大家能够体会到我在第一节课中 ...

  9. 用js转换joson返回数据库的时间格式为/Date(*************)/

    原理是取中间的毫秒数,再转换成js的Date类型 function ChangeDateFormat(val) { if (val != null) { var date = new Date(par ...

  10. Resharper快捷键

    建议你使用 Reshaper 的快捷键,不要担心 Reshaper 会把你原来的快捷键设置给覆盖了,因为如果某个快捷键和 VS 是冲突的,Reshaper会让你自己选择需要使用 VS 还是 Resha ...