Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/279.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
使用ADO.Net在C#中读取excel文件时出现问题_C#_.net_Excel_Ado.net - Fatal编程技术网

使用ADO.Net在C#中读取excel文件时出现问题

使用ADO.Net在C#中读取excel文件时出现问题,c#,.net,excel,ado.net,C#,.net,Excel,Ado.net,我今天刚开始读C#,读excel文件有困难 以下是我所做的: OleDbConnection connection = new OleDbConnection(@"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + filePath + @";Extended Properties=""Excel 12.0;HDR=YES;"""); OleDbCommand command = new OleDbCommand("SELECT * FROM [

我今天刚开始读C#,读excel文件有困难

以下是我所做的:

OleDbConnection connection = new OleDbConnection(@"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + filePath + @";Extended Properties=""Excel 12.0;HDR=YES;""");

OleDbCommand command = new OleDbCommand("SELECT * FROM [Sheet$]", connection);

connection.Open();

OleDbDataReader reader = command.ExecuteReader();
我有一个例外,说它找不到“Sheet$” (我无法复制/粘贴异常,因为消息是法语的,我还不知道如何使用英语的通用消息)

有人能告诉我我做错了什么吗

我按照他们在教程里说的做了

谢谢,真的

您可以从Excel文件中获取“表格”(工作表或命名范围)列表:

DataTable schema = connection.GetSchema(OleDbMetaDataCollectionNames.Tables);

TABLE_NAME字段是您应该在查询中使用的字段。如果该值周围有单引号,则需要包含这些引号。例如,我的文件有名为“GP”和“Kimberly Clark”的工作表。在模式表中,它们显示为“GP$”和“Kimberly Clark$”。在查询中,我会将它们引用为“[GP$]”或“['Kimberly Clark$””。

是工作表“Sheet$”的名称吗?你试过Sheet 1吗?名字是Sheet。我认为美元是强制性的,这在所有的例子中都有。但是[Sheet]的异常是找不到“Sheet”。我重新启动了VS,我的代码正常工作,我不知道为什么。但是你说的真的很有用,谢谢!!