這篇文章主要介紹了ASP.NET中 Execl導出的六種方法實例,有需要的朋友可以參考一下
代碼如下: /// <summary> /// 導出Excel /// </summary> /// <param name="page"></param> /// <param name="dt"></param> //方法一: public void ImportExcel(Page page, DataTable dt) { try { string filename = Guid.NewGuid().ToString() + ".xls"; string webFilePath = page.Server.MapPath("/" + filename); CreateExcelFile(webFilePath, dt); using (FileStream fs = new FileStream(webFilePath, FileMode.OpenOrCreate)) { //讓用戶輸入下載的本地地址 page.Response.Clear(); page.Response.Buffer = true; page.Response.Charset = "GB2312"; //page.Response.AppendHeader("Content-Disposition", "attachment;filename=MonitorResult.xls"); page.Response.AppendHeader("Content-Disposition", "attachment;filename=" + filename); page.Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312"); page.Response.ContentType = "application/ms-excel"; // 讀取excel數據到內存 byte[] buffer = new byte[fs.Length - 1]; fs.Read(buffer, 0, (int)fs.Length - 1); // 寫到aspx頁面 page.Response.BinaryWrite(buffer); page.Response.Flush(); //this.ApplicationInstance.CompleteRequest(); //停止頁的執行 fs.Close(); fs.Dispose(); //刪除臨時文件 File.Delete(webFilePath); } } catch (Exception ex) { throw ex; } } 方法二: 代碼如下: public void ImportExcel(Page page, DataSet ds) { try { string filename = Guid.NewGuid().ToString() + ".xls"; string webFilePath = page.Server.MapPath("/" + filename); CreateExcelFile(webFilePath, ds); using (FileStream fs = new FileStream(webFilePath, FileMode.OpenOrCreate)) { //讓用戶輸入下載的本地地址 page.Response.Clear(); page.Response.Buffer = true; page.Response.Charset = "GB2312"; //page.Response.AppendHeader("Content-Disposition", "attachment;filename=MonitorResult.xls"); page.Response.AppendHeader("Content-Disposition", "attachment;filename=" + filename); page.Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312"); page.Response.ContentType = "application/ms-excel"; // 讀取excel數據到內存 byte[] buffer = new byte[fs.Length - 1]; fs.Read(buffer, 0, (int)fs.Length - 1); // 寫到aspx頁面 page.Response.BinaryWrite(buffer); page.Response.Flush(); //this.ApplicationInstance.CompleteRequest(); //停止頁的執行 fs.Close(); fs.Dispose(); //刪除臨時文件 File.Delete(webFilePath); } } catch (Exception ex) { throw ex; } } 方法三: 代碼如下: public void ImportExcel(Page page, DataTable dt1, DataTable dt2, string conditions) { try { string filename = Guid.NewGuid().ToString() + ".xls"; string webFilePath = page.Server.MapPath("/" + filename); CreateExcelFile(webFilePath, dt1, dt2, conditions); using (FileStream fs = new FileStream(webFilePath, FileMode.OpenOrCreate)) { //讓用戶輸入下載的本地地址 page.Response.Clear(); page.Response.Buffer = true; page.Response.Charset = "GB2312"; //page.Response.AppendHeader("Content-Disposition", "attachment;filename=MonitorResult.xls"); page.Response.AppendHeader("Content-Disposition", "attachment;filename=" + filename); page.Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312"); page.Response.ContentType = "application/ms-excel"; // 讀取excel數據到內存 byte[] buffer = new byte[fs.Length - 1]; fs.Read(buffer, 0, (int)fs.Length - 1); // 寫到aspx頁面 page.Response.BinaryWrite(buffer); page.Response.Flush(); //this.ApplicationInstance.CompleteRequest(); //停止頁的執行 fs.Close(); fs.Dispose(); //刪除臨時文件 File.Delete(webFilePath); } } catch (Exception ex) { throw ex; } } 方法四: 代碼如下: private void CreateExcelFile(string filePath, DataTable dt) { if (File.Exists(filePath)) { File.Delete(filePath); } OleDbConnection oleDbConn = new OleDbConnection(); OleDbCommand oleDbCmd = new OleDbCommand(); try { string sSql = ""; oleDbConn.ConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + filePath + @";Extended ProPerties=""Excel 8.0;HDR=Yes;"""; oleDbConn.Open(); oleDbCmd.CommandType = CommandType.Text; oleDbCmd.Connection = oleDbConn; //寫列名 sSql = "CREATE TABLE sheet1("; for (int i = 0; i < dt.Columns.Count; i++) { if (i < dt.Columns.Count - 1) { if (dt.Columns[i].DataType.Name == "String") { sSql += "[" + dt.Columns[i].ColumnName + "] Text,"; } else if (dt.Columns[i].DataType.Name == "DateTime") { sSql += "[" + dt.Columns[i].ColumnName + "] Datetime,"; } else { sSql += "[" + dt.Columns[i].ColumnName + "] Decimal,"; } } else { if (dt.Columns[i].DataType.Name == "String") { sSql += "[" + dt.Columns[i].ColumnName + "] Text)"; } else if (dt.Columns[i].DataType.Name == "DateTime") { sSql += "[" + dt.Columns[i].ColumnName + "] DateTime)"; } else { sSql += "[" + dt.Columns[i].ColumnName + "] Decimal)"; } } } oleDbCmd.CommandText = sSql; oleDbCmd.ExecuteNonQuery(); for (int j = 0; j < dt.Rows.Count; j++) { sSql = "INSERT INTO sheet1 VALUES("; for (int i = 0; i < dt.Columns.Count; i++) { if (i < dt.Columns.Count - 1) { if (DBNull.Value.Equals(dt.Rows[j][i])) { sSql += "NULL,"; } else { if (dt.Columns[i].DataType.Name == "Decimal") { sSql += dt.Rows[j][i].ToString() + ","; } else { sSql += "'" + dt.Rows[j][i].ToString() + "',"; } } } else if (DBNull.Value.Equals(dt.Rows[j][i])) { sSql += "NULL)"; } else { if (dt.Columns[i].DataType.Name == "Decimal") { sSql += dt.Rows[j][i].ToString() + ")"; } else { sSql += "'" + dt.Rows[j][i].ToString() + "')"; } } } oleDbCmd.CommandText = sSql; oleDbCmd.ExecuteNonQuery(); } } catch (System.Exception ex) { throw ex; } finally { //斷開連接 oleDbCmd.Dispose(); oleDbConn.Close(); oleDbConn.Dispose(); } } 方法五: 復制代碼 代碼如下: private void CreateExcelFile(string filePath, DataSet ds) { if (File.Exists(filePath)) { File.Delete(filePath); } OleDbConnection oleDbConn = new OleDbConnection(); OleDbCommand oleDbCmd = new OleDbCommand(); try { string sSql = ""; oleDbConn.ConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + filePath + @";Extended ProPerties=""Excel 8.0;HDR=Yes;"""; oleDbConn.Open(); oleDbCmd.CommandType = CommandType.Text; oleDbCmd.Connection = oleDbConn; //寫列名 for(int k=0;k<ds.Tables.Count;k++) { DataTable dt = ds.Tables[k]; sSql = "CREATE TABLE sheet" + (k + 1).ToString() + "("; for (int i = 0; i < dt.Columns.Count; i++) { if (i < dt.Columns.Count - 1) { if (dt.Columns[i].DataType.Name == "String" || dt.Columns[i].DataType.Name=="Guid") { sSql += "["+dt.Columns[i].ColumnName + "] Text,"; } else if (dt.Columns[i].DataType.Name == "DateTime") { sSql += "[" + dt.Columns[i].ColumnName + "] Datetime,"; } else { sSql += "[" + dt.Columns[i].ColumnName + "] Decimal,"; } } else { if (dt.Columns[i].DataType.Name == "String") { sSql += "[" + dt.Columns[i].ColumnName + "] Text)"; } else if (dt.Columns[i].DataType.Name == "DateTime") { sSql += "[" + dt.Columns[i].ColumnName + "] DateTime)"; } else { sSql += "[" + dt.Columns[i].ColumnName + "] Decimal)"; } } } oleDbCmd.CommandText = sSql; oleDbCmd.ExecuteNonQuery(); for (int j = 0; j < dt.Rows.Count; j++) { sSql = "INSERT INTO sheet" + (k + 1).ToString() + " VALUES("; for (int i = 0; i < dt.Columns.Count; i++) { if (i < dt.Columns.Count - 1) { if (DBNull.Value.Equals(dt.Rows[j][i])) { sSql += "NULL,"; } else { if (dt.Columns[i].DataType.Name == "Decimal") { sSql += dt.Rows[j][i].ToString() + ","; } else { sSql += "'" + dt.Rows[j][i].ToString().Replace("'", "''") + "',"; } } } else if (DBNull.Value.Equals(dt.Rows[j][i])) { sSql += "NULL)"; } else { if (dt.Columns[i].DataType.Name == "Decimal") { sSql += dt.Rows[j][i].ToString() + ")"; } else { sSql += "'" + dt.Rows[j][i].ToString().Replace("'","''") + "')"; } } } oleDbCmd.CommandText = sSql; oleDbCmd.ExecuteNonQuery(); } } } catch (System.Exception ex) { throw ex; } finally { //斷開連接 oleDbCmd.Dispose(); oleDbConn.Close(); oleDbConn.Dispose(); } } 方法六: 復制代碼 代碼如下: private void CreateExcelFile(string filePath, DataTable dt1,DataTable dt2,string conditions) { if (File.Exists(filePath)) { File.Delete(filePath); } OleDbConnection oleDbConn = new OleDbConnection(); OleDbCommand oleDbCmd = new OleDbCommand(); try { string sSql = ""; oleDbConn.ConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + filePath + @";Extended ProPerties=""Excel 8.0;HDR=Yes;"""; oleDbConn.Open(); oleDbCmd.CommandType = CommandType.Text; oleDbCmd.Connection = oleDbConn; //寫列名 sSql = "CREATE TABLE sheet1("; DataTable dt = dt1.Copy(); dt.Columns.Remove("MGUID"); for (int i = 0; i < dt.Columns.Count; i++) { if (i < dt.Columns.Count - 1) { if (dt.Columns[i].DataType.Name == "String") { sSql += "[" + dt.Columns[i].ColumnName + "] Text,"; } else if (dt.Columns[i].DataType.Name == "DateTime") { sSql += "[" + dt.Columns[i].ColumnName + "] Datetime,"; } else { sSql += "[" + dt.Columns[i].ColumnName + "] Decimal,"; } } else { if (dt.Columns[i].DataType.Name == "String") { sSql += "[" + dt.Columns[i].ColumnName + "] Text)"; } else if (dt.Columns[i].DataType.Name == "DateTime") { sSql += "[" + dt.Columns[i].ColumnName + "] DateTime)"; } else { sSql += "[" + dt.Columns[i].ColumnName + "] Decimal)"; } } } oleDbCmd.CommandText = sSql; oleDbCmd.ExecuteNonQuery(); DataView dv = new DataView(); dv.Table = dt; DataView dv1 = new DataView(); dv1.Table = dt1; if (conditions != "") { dv.RowFilter = conditions; dv1.RowFilter = conditions; } dt = dv.ToTable(); dt1 = dv1.ToTable(); string MGUIDs = ""; for (int j = 0; j < dt.Rows.Count; j++) { MGUIDs += ",'" + dt1.Rows[j]["MGUID"].ToString() + "'"; sSql = "INSERT INTO sheet1 VALUES("; for (int i = 0; i < dt.Columns.Count; i++) { if (i < dt.Columns.Count - 1) { if (DBNull.Value.Equals(dt.Rows[j][i])) { sSql += "NULL,"; } else { if (dt.Columns[i].DataType.Name == "Decimal") { sSql += dt.Rows[j][i].ToString() + ","; } else { sSql += "'" + dt.Rows[j][i].ToString() + "',"; } } } else if (DBNull.Value.Equals(dt.Rows[j][i])) { sSql += "NULL)"; } else { if (dt.Columns[i].DataType.Name == "Decimal") { sSql += dt.Rows[j][i].ToString() + ")"; } else { sSql += "'" + dt.Rows[j][i].ToString() + "')"; } } } oleDbCmd.CommandText = sSql; oleDbCmd.ExecuteNonQuery(); } if (dt2 != null) { sSql = "CREATE TABLE sheet21("; dt = dt2.Copy(); dt.Columns.Remove("MGUID"); dt.Columns.Remove("DGUID"); for (int i = 0; i < dt.Columns.Count; i++) { if (i < dt.Columns.Count - 1) { if (dt.Columns[i].DataType.Name == "String") { sSql += "[" + dt.Columns[i].ColumnName + "] Text,"; } else if (dt.Columns[i].DataType.Name == "DateTime") { sSql += "[" + dt.Columns[i].ColumnName + "] Datetime,"; } else { sSql += "[" + dt.Columns[i].ColumnName + "] Decimal,"; } } else { if (dt.Columns[i].DataType.Name == "String") { sSql += "[" + dt.Columns[i].ColumnName + "] Text)"; } else if (dt.Columns[i].DataType.Name == "DateTime") { sSql += "[" + dt.Columns[i].ColumnName + "] DateTime)"; } else { sSql += "[" + dt.Columns[i].ColumnName + "] Decimal)"; } } } oleDbCmd.CommandText = sSql; oleDbCmd.ExecuteNonQuery(); dv = new DataView(); dv.Table = dt2; if (MGUIDs != "") { dv.RowFilter = "MGUID in(" + MGUIDs.Substring(1) + ")"; } dt = dv.ToTable(); for (int j = 0; j < dt.Rows.Count; j++) { sSql = "INSERT INTO sheet1 VALUES("; for (int i = 0; i < dt.Columns.Count; i++) { if (i < dt.Columns.Count - 1) { if (DBNull.Value.Equals(dt.Rows[j][i])) { sSql += "NULL,"; } else { if (dt.Columns[i].DataType.Name == "Decimal") { sSql += dt.Rows[j][i].ToString() + ","; } else { sSql += "'" + dt.Rows[j][i].ToString() + "',"; } } } else if (DBNull.Value.Equals(dt.Rows[j][i])) { sSql += "NULL)"; } else { if (dt.Columns[i].DataType.Name == "Decimal") { sSql += dt.Rows[j][i].ToString() + ")"; } else { sSql += "'" + dt.Rows[j][i].ToString() + "')"; } } } oleDbCmd.CommandText = sSql; oleDbCmd.ExecuteNonQuery(); } } } catch (System.Exception ex) { throw ex; } finally { //斷開連接 oleDbCmd.Dispose(); oleDbConn.Close(); oleDbConn.Dispose(); } }