將Excel表格數據轉換成Datatable


 

/// <summary>
/// 將Excel表格數據轉換成Datatable
/// </summary>
/// <param name="fileUrl">文件地址</param>
/// <param name="table">table命名</param>
/// <returns></returns>

public DataTable GetExcelDatatable(string fileUrl, string table)
{
//office2007之前 僅支持.xls
//const string cmdText = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source={0};Extended Properties='Excel 8.0;IMEX=1';";
//支持.xls和.xlsx,即包括office2010等版本的 HDR=Yes代表第一行是標題,不是數據;
string cmdText = "Provider=Microsoft.Ace.OleDb.12.0;Data Source={0};Extended Properties='Excel 12.0; HDR=Yes; IMEX=1'";

System.Data.DataTable dt = null;
//建立連接
OleDbConnection conn = new OleDbConnection(string.Format(cmdText, fileUrl));
try
{
//打開連接
if (conn.State == ConnectionState.Broken || conn.State == ConnectionState.Closed)
{
conn.Open();
}


System.Data.DataTable schemaTable = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null);
string sqlstr = string.Empty;
foreach (DataRow item in schemaTable.Rows)
{
//獲取Excel的第一個Sheet名稱
string sheetName = item["TABLE_NAME"].ToString().Trim();
//查詢sheet中的數據
string strSql = "select * from [" + sheetName + "]";
OleDbDataAdapter da = new OleDbDataAdapter(strSql, conn);
DataSet ds = new DataSet();
try
{
da.Fill(ds, table);
}
catch (Exception)
{

throw;
}

dt = ds.Tables[0];
}
return dt;
}
catch (Exception exc)
{
throw exc;
}
finally
{
conn.Close();
conn.Dispose();
}
}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



猜您在找 用xmind轉換成excel表格 C#將HTML表格 Json轉換成DataTable 將數組轉換成datatable Datatable數據轉換成excel導出時 數值類型在EXCEL中為文本形式 無法進行統計 如何快速將pdf中的表格轉換成excel 便簽記事本怎么轉換成excel表格? C# List轉換成DataTable C#_List轉換成DataTable
 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM
轉換成DataTable JSON數據轉換成table表格