Asp.Net將數據導入到Excle表中

前言:

在項目中我們經常會遇到對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;
        }

上面的代碼是經過我實踐的,大家只需把參數改下就行!

結尾:

     分享:忍!

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章