Asp.Net将数据导入到Excle表中

前言:

在项目中我们经常会遇到对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;
        }

上面的代码是经过我实践的,大家只需把参数改下就行!

结尾:

     分享:忍!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值