【C#】C#使用OleDb读取Excel表格数据及遇到的问题

读取Excel表格数据的方法

/// <summary>
/// 读取excel返回DataTable
/// </summary>
/// <param name="fileName"></param>
/// <param name="sheetName"></param>
/// <returns></returns>
private System.Data.DataTable ExcelToDataTable(string fileName, string sheetName)
{
    System.Data.DataTable dt = null;
    try
    {
        string connectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + fileName + ";Extended Properties='Excel 8.0;HDR=No;IMEX=1;'";
        //connectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + fileName + ";Extended Properties='Excel 8.0;HDR=No;IMEX=1;'";
        //connectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + fileName + ";Extended Properties='Excel 12.0;HDR=No;IMEX=1;'";


        string selectCommandText = "SELECT * FROM [" + sheetName + "$]";

        using (OleDbDataAdapter adapter = new OleDbDataAdapter(selectCommandText, connectionString))
        {
            dt = new System.Data.DataTable();
            adapter.Fill(dt);
            return dt;
        }
    }
    catch(Exception ex)
    {
        MessageBox.Show(ex.ToString());
    }
    return dt;
}

HDR = Yes 时表示工作表的第一行为标题,获取的DataTable数据则会从第二行开始获取

 

获取数据

 System.Data.DataTable  dt = ExcelToDataTable(fileName, "All");

 string str = dt.Rows[0][0].ToString();

可能会遇到的问题1:

未在本地计算机上注册“Microsoft.Jet.OLEDB.4.0”提供程序。

解决方法:VS--生成--配置管理器--平台--新建,在新建平台选择x86,确定

 

可能会遇到的问题2:

外部表不是预期的格式。

这个问题真的很奇怪,一开始也不知为什么,后面问题出现多了,总结出来,是因为在读取表格数据时需要打开Excel表格,试了很多次都是这样,没有打开表格时就出错,打开表格就正常

解决方法:打开需要操作的Excel表格再执行读取操作

 

 

 

 

 

 

 

相关推荐
©️2020 CSDN 皮肤主题: 精致技术 设计师:CSDN官方博客 返回首页