前言:
在项目中我们经常会遇到对Excle操作的问题,我所做的需求就是将数据库中数据导入到Excle表格中。这个当时还是很头大的,毕竟第一次做这方面的需求,遇到了很多坑。
给大家分享一个关于Excle操作的网站:https://yq.aliyun.com/zt/326129
下面直接上代码:(对Excle的文件进行操作是电脑上首先要安装一个Excle的组件)
链接:https://download.youkuaiyun.com/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;
}
上面的代码是经过我实践的,大家只需把参数改下就行!
结尾:
分享:忍!

320

被折叠的 条评论
为什么被折叠?



