将Excel表格数据转换成Datatable

Posted abelangelo

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了将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();
}
}

以上是关于将Excel表格数据转换成Datatable的主要内容,如果未能解决你的问题,请参考以下文章

c#如何把Json转成DataTable每一行都一一对应下面多出来的列自动添加到后方

怎么将pdf转换成excel表格啊?

如何将excel表格转成在线文档

pdf怎么转换成excel

excel表格如何将十六进制转换成浮点数

如何将DataGridView转换为DataTable?