我正在使用C#和OleDB(12.0)读取excel文件。在那里,我必须使用我想要阅读的表单的名称([Sheet1$]
)指定select语句。
this.dataAdapter =
new OleDbDataAdapter("SELECT * FROM [Sheet1$]", connectionString);
是否可以选择第一张纸,无论名称是什么?
谢谢。
答案 0 :(得分:5)
请参阅此答案,了解如何按顺序获取工作表名称列表:Using Excel OleDb to get sheet names IN SHEET ORDER
这是我的版本,有点短:
public static IEnumerable<string> GetExcelSheetNames(string excelFile)
{
var connectionString = "Provider=Microsoft.Jet.OLEDB.4.0;" +
"Data Source=" + excelFile + ";Extended Properties=Excel 8.0;";
using (var connection = new OleDbConnection(connectionString))
{
connection.Open();
using (var dt = connection.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null))
{
return (dt ?? new DataTable())
.Rows
.Cast<DataRow>()
.Select(row => row["TABLE_NAME"].ToString());
}
}
}