asp.net實現資料從DataTable匯入到Excel檔案並建立表的方法_實用技巧

來源:互聯網
上載者:User

本文執行個體講述了asp.net實現資料從DataTable匯入到Excel檔案並建立表的方法。分享給大家供大家參考,具體如下:

/// <summary>/// 把資料從DataTable匯入到Excel檔案裡/// </summary>/// <param name="dataTable">資料來源</param>/// <param name="AbsoluteExcelFilePath">Excel檔案的絕對路徑</param>/// <param name="TblColName">TBL裡對應的列名</param>/// <param name="ColumnName">Excel中對應的列名</param>/// <returns>操作成功返回True,失敗返回False</returns>public static bool ExportDataToExcel(DataTable dataTable, string AbsoluteExcelFilePath, string[] TblColName, string[] ColumnName){  int k = 0;  if (dataTable == null) return false;  OleDbConnection Conn = new OleDbConnection();  try  {   string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + AbsoluteExcelFilePath + ";Mode=Share Deny None;Extended Properties=Excel 8.0;Jet OLEDB:Create System Database=True";   Conn = new OleDbConnection(strConn);   Conn.Open();   OleDbCommand command = Conn.CreateCommand();   string strSQL = "";   if (dataTable.Columns != null)   {    //建表    strSQL = "CREATE TABLE " + dataTable.TableName + "(";    for (int i = 0; i < ColumnName.Length; i++)    {     strSQL += ColumnName[i] + " TEXT,";    }    strSQL = strSQL.Substring(0, strSQL.Length - 1);    strSQL += ")";    command.CommandText += strSQL;    command.ExecuteNonQuery();    if (dataTable.Rows.Count > 0)    {     //匯入資料     foreach (DataRow row in dataTable.Rows)     {      strSQL = "insert into " + dataTable.TableName + "(";      for (k = 0; k < TblColName.Length; k++)      {       strSQL += ColumnName[k] + ",";      }      strSQL = strSQL.Substring(0, strSQL.Length - 1);      strSQL += ") values( ";      for (k = 0; k < TblColName.Length; k++)      {       strSQL += "'" + row[TblColName[k]] + "',";      }      strSQL = strSQL.Substring(0, strSQL.Length - 1);      strSQL += ")";      command.CommandText = strSQL;      command.ExecuteNonQuery();     }    }   }  }  catch (Exception ex)  {   Conn.Close();   throw new Exception(ex.Message);   return false;  }  Conn.Close();  return true;}

調用方法:

DataSet ds = (DataSet)Session["listMobile"];//獲得要匯出的表格的值if (ds.Tables[0].Rows.Count <= 0){ Page.RegisterStartupScript("", "<mce:script type="text/javascript"><!--alert('沒有內容不能匯出!')// --></mce:script>");}else{ //EXCEL頁面的名稱 string[] tableName = { "["+DateTime.Now.ToString("yyyyMMddhhmmss")+"]" }; string fileName = tools.CreateID() + ".xls"; string filePath = Server.MapPath("..//DownloadFiles//" + fileName); if (tools.ExportDataToExcel(ds, filePath, tableName)==true) {  Response.Clear();  Response.Buffer = true;  Response.Charset = "GB2312";  Response.AppendHeader("Content-Disposition", "attachment;filename=" + fileName);  Response.ContentType = "application/vnd.ms-excel";  this.EnableViewState = false;  Response.WriteFile(filePath);  Response.Flush();  if (System.IO.File.Exists(filePath)) System.IO.File.Delete(filePath);  Response.Redirect(this.Request.UrlReferrer.AbsoluteUri, true);  Response.End(); }}

希望本文所述對大家asp.net程式設計有所協助。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.