前言:
在項目中我們經常會遇到對Excle操作的問題,我所做的需求就是將數據庫中數據導入到Excle表格中。這個當時還是很頭大的,畢竟第一次做這方面的需求,遇到了很多坑。
給大家分享一個關於Excle操作的網站:https://yq.aliyun.com/zt/326129
下面直接上代碼:(對Excle的文件進行操作是電腦上首先要安裝一個Excle的組件)
鏈接:https://download.csdn.net/download/greycastle/11614737
/// <summary>
/// 將數據填充到Excle
/// </summary>
/// <param name="userInfoList">list集合數據</param>
/// <param name="filePath">保存文件的路徑</param>
/// <returns></returns>
public static bool GetSqlDataToExcle(List<UserInfo> userInfoList, string filePath)
{
string strConn = null;//通過後綴執行不同的Excle連接字符串
//string dataName = null;
string fileExtendName = filePath.Split('.')[filePath.Split('.').Length - 1];
System.Data.DataTable dt = new System.Data.DataTable();
dt.Columns.Add("userAccount");
dt.Columns.Add("userPwd");
dt.Columns.Add("userName");
dt.Columns.Add("userAge");
dt.Columns.Add("userAddress");
dt.Columns.Add("userPhone");
foreach (var userInfo in userInfoList)
{
dt.Rows.Add(userInfo.Account, userInfo.Pwd, userInfo.Name, userInfo.Age, userInfo.Address, userInfo.Phone);
}
//DoExport(dt,filePath)
if (fileExtendName.ToLower() == "xls")
{
strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Persist Security Info=True;Data Source=" + filePath + ";Extended Properties=Excel 8.0;";
}
if (fileExtendName.ToLower() == "xlsx")
{
//strConn = "Provider=Microsoft.Ace.OleDb.12.0;Persist Security Info=False;Data Source="+filePath+";Extended Properties="Excel 12.0;HDR=YES;IMEX=1;""";
strConn = String.Format(@"Provider=Microsoft.Ace.OleDb.12.0;Persist Security Info=False;Data Source={0};Extended Properties=""Excel 12.0;HDR=YES;IMEX=0;""", filePath);
}
System.Data.OleDb.OleDbConnection conn = new System.Data.OleDb.OleDbConnection(strConn);
OleDbCommand cmd = null;//操作Excle的對象
bool result = false;//操作的結果
conn.Open();
//cmd = new OleDbCommand("create table [sheet1]([userAccount] Text,[userPwd] Text,[userName] Text,[userAge] Text,[userAddress] Text,[userPhone] Text)", conn);
//cmd.ExecuteNonQuery();//保存創建的表
string strSQL = "INSERT INTO [Sheet1$] ([userAccount], [userPwd],[userName],[userAge],[userAddress],[userPhone]) VALUES (?,?,?,?,?,?)";
//cmd.ExecuteNonQuery();
cmd = new OleDbCommand(strSQL, conn);
for (int i = 0; i < 6; i++)
{
cmd.Parameters.Add(i.ToString(), OleDbType.VarChar);
}
DataView dv = dt.DefaultView;
foreach (DataRowView row in dv)
{
cmd.Parameters[0].Value = row["userAccount"].ToString();
cmd.Parameters[1].Value = row["userPwd"].ToString();
cmd.Parameters[2].Value = row["userName"].ToString();
cmd.Parameters[3].Value = row["userAge"].ToString();
cmd.Parameters[4].Value = row["userAddress"].ToString();
cmd.Parameters[5].Value = row["userPhone"].ToString();
int num1 = cmd.ExecuteNonQuery();
}
if (cmd != null)
{
result = true;
}
else
{
result = false;
}
conn.Close();
conn.Dispose();
conn.Dispose();
return result;
}
上面的代碼是經過我實踐的,大家只需把參數改下就行!
結尾:
分享:忍!