亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > .NET > 正文

Asp.net MVC實現生成Excel并下載功能

2024-07-10 13:32:50
字體:
來源:轉載
供稿:網友

本文實例為大家分享了Asp.net MVC實現生成Excel并下載的具體代碼,供大家參考,具體內容如下

由于項目上的需求,需要導出指定條件的Excel文件。經過一翻折騰終于實現了。

現在把代碼貼出來分享

(直接把我們項目里面的一部份輔助類的代碼分享一下)

我們項目使用的是Asp.Net MVC4.0模式。

每個ActionResult必然會返回一個View或Json等(View或Json中的參數都是object類型的)

所以我們需要一個公共類來統一定義操作的“成功或失敗”的狀態或返回操作的消息 ,以及有利于使用jquery $.get() 、$.post()的接收返回參數時的統一性。

以下是StatusMessageData類。(當然,如果只想要導出Excel,這個類是不需要定義的。)

/// <summary> /// 輔助傳輸StatusMessage數據 /// </summary> [Serializable] public sealed class StatusMessageData {  private StatusMessageType messageType;  /// <summary>  /// 提示消息類別  /// </summary>  public StatusMessageType MessageType  {   get { return messageType; }   set { messageType = value; }  }  private string messageContent = string.Empty;  /// <summary>  /// 信息內容  /// </summary>  public string MessageContent  {   get { return messageContent; }   set { messageContent = value; }  }  private object data;  /// <summary>  /// 數據   /// </summary>  public object Data  {   get { return data; }   set { data = value; }  }  /// <summary>  /// 構造器  /// </summary>  /// <param name="messageType">消息類型</param>  /// <param name="messageContent">消息內容</param>  public StatusMessageData(StatusMessageType messageType, string messageContent, object data)  {   this.messageType = messageType;   this.messageContent = messageContent;   this.data = data;  }  public StatusMessageData(StatusMessageType messageType, string messageContent)  {   this.messageType = messageType;   this.messageContent = messageContent;  }  public StatusMessageData()  {  } } /// <summary> /// 提示消息類別 /// </summary> public enum StatusMessageType {  /// <summary>  /// 成功  /// </summary>  Success = 1,  /// <summary>  /// 錯誤  /// </summary>  Error = -1,  /// <summary>  /// 提示信息  /// </summary>  Hint = 0,  /// <summary>  /// 提醒登錄  /// </summary>  Login = 5,  /// <summary>  /// 提示重定向  /// </summary>  Redirect = 6, }

在Controller中定義ExportExcel ActionResult

[HttpPost]  public ActionResult ExportExcel(SearchModel model)  {         StatusMessageData result = new StatusMessageData();   if (model.Data == null || model.Data.Count <= 0)   {    result.MessageType = StatusMessageType.Error;    result.MessageContent = "沒有要下載的數據";    return Json(result);   }   string fileglobal = "";   //組織Excel表格   StringBuilder sb = new StringBuilder(400);   sb.Append("<table cellspacing='0' rules='all' border='1'>");   sb.Append("<thead>");   sb.Append("<tr>");   sb.Append("<th>列一</th>");   sb.Append("<th>列二</th>");   sb.Append("<th>列三</th>");   sb.Append("<th>列四</th>");   sb.Append("</tr>");   sb.Append("</thead>");   sb.Append("<tbody>");   try   {      foreach (var item in model.Data)      {       sb.Append("<tr>");       sb.Append("<td>");       sb.Append(item.column1);       sb.Append("</td>");       sb.Append("<td>");       sb.Append(item.column2);       sb.Append("</td>");       sb.Append("<td>");       sb.Append(item.column3);       sb.Append("</td>");       sb.Append("<td>");       sb.Append(item.column4);       sb.Append("</td>");       sb.Append("</tr>");             }    }       sb.Append("</tbody>");    sb.Append("</table>");    //以UTF8格式寫入文件    byte[] contentBytes = Encoding.UTF8.GetBytes(sb.ToString());    string rootDirServerPath = "將生成的文件保存在指定的目錄名稱";    //由于我們項目上下載Excel文件基本沒有并發的情況,所以只用年月日時分秒來命名文件就可以避免生成相同文件名文件的問題。    string fileSaveName = "下載的文件名稱_" + DateTime.Now.ToString("yyyyMMddHHmmss") + ".xls";    string rootDirServerPhysicPath = Server.MapPath("~" + rootDirServerPath);    if (!Directory.Exists(rootDirServerPhysicPath))    {     Directory.CreateDirectory(rootDirServerPhysicPath);    }    string[] strFiles = Directory.GetFiles(rootDirServerPhysicPath);    if (strFiles.Length > 0)    {     foreach (string strFile in strFiles)     {      System.IO.File.Delete(strFile);     }    }    //以下是將文件保存到指定目錄    string userFailedSummaryFileSavePath = rootDirServerPhysicPath + "/" + fileSaveName;    if (System.IO.File.Exists(userFailedSummaryFileSavePath))    {     System.IO.File.Delete(userFailedSummaryFileSavePath);    }    System.IO.File.WriteAllBytes(userFailedSummaryFileSavePath, contentBytes);    //拼裝好要下載文件的全路徑。    fileglobal = rootDirServerPath + "/" + fileSaveName;   }   catch (Exception ex)   {    result.MessageType = StatusMessageType.Error;    result.MessageContent = ex.Message.ToString();    return Json(result);   }   result.MessageType = StatusMessageType.Success;   result.MessageContent = "正在下載,請稍候...";   result.Data = fileglobal;   return Json(result);  } 

完成了生成Excel的操作后,在頁面進行異步調用。

$("#export-excel").click(function (e) {    e.preventDefault();    $.post("Controller/ExportExcel.aspx", $("#Form1").serialize(), function (data) {      art.dialog.tips(data.MessageContent, 1.5, data.MessageType, function () {        if (data.MessageType == 1) {          window.open(data.Data);        } else {          //錯誤操作        }      });    });  });

以上就是我們項目中關于Excel生成到下載的全部操作。

考慮的情況比較少,寫的比較簡單。

如果大家有什么好的想法,可以留言,我肯定會學習并實踐好再拿出來分享。

非常感謝。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到ASP.NET教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品美女无圣光视频| 国产精品福利片| 国语自产在线不卡| 国产91av在线| 欧美亚洲另类视频| 在线视频欧美日韩| 欧美性猛交xxxx免费看漫画| 欧美乱人伦中文字幕在线| 国产精品爽爽ⅴa在线观看| 国产日韩精品视频| 国产欧美va欧美va香蕉在| 最新国产精品拍自在线播放| 日韩av最新在线观看| 在线观看国产欧美| 97免费视频在线| 57pao成人永久免费视频| 亚洲精品一区在线观看香蕉| 欧美裸身视频免费观看| 国产精品专区一| 91啪国产在线| 成人欧美在线观看| 国产成人精品电影久久久| 国产精品天天狠天天看| 亚洲色图第一页| 亚洲人成人99网站| 国产日韩欧美91| 亚洲第一区中文99精品| 国产精品黄色av| 庆余年2免费日韩剧观看大牛| 亚洲黄色av女优在线观看| 日韩中文字幕视频在线| 国产精品十八以下禁看| 国产成人一区三区| 欧美理论电影在线观看| 久久视频国产精品免费视频在线| 2020国产精品视频| 亚洲毛片一区二区| 亚洲有声小说3d| 亚洲视频在线观看| 欧美国产日韩xxxxx| www日韩中文字幕在线看| 日韩精品中文字幕在线观看| 在线视频精品一| 在线成人中文字幕| 国内揄拍国内精品少妇国语| 国产精品免费看久久久香蕉| 亚洲va电影大全| 国产精品美女久久| 精品动漫一区二区三区| www欧美xxxx| 亚洲一区免费网站| 亚洲欧美国产精品| 欧美在线精品免播放器视频| 成人啪啪免费看| 日韩精品视频在线免费观看| 色妞久久福利网| 日韩av不卡在线| 国产一区二区三区日韩欧美| 久久精品中文字幕免费mv| 久久好看免费视频| 亚洲成人免费网站| 国产69久久精品成人| 欧美激情综合色综合啪啪五月| 亚洲精品女av网站| 久久久久久美女| 国产91色在线免费| 日韩电影中文字幕av| 国产在线高清精品| 日韩av综合网| 久久91亚洲人成电影网站| 亚洲国产精品成人精品| 国产成人精品综合| 日韩欧美在线网址| 精品福利樱桃av导航| 亚洲国产美女久久久久| 97精品国产97久久久久久免费| 色999日韩欧美国产| 欧美最猛性xxxxx(亚洲精品)| 中文字幕亚洲综合久久| 国产91免费观看| 欧美亚洲一级片| 一区二区三区四区精品| 91免费精品国偷自产在线| 亚洲免费一在线| 日韩欧美主播在线| 91在线网站视频| 久久成人国产精品| 成人黄色激情网| 欧美日本在线视频中文字字幕| 亚洲肉体裸体xxxx137| 国产精品视频99| 久久人体大胆视频| 91av视频导航| 欧美高清自拍一区| 国产亚洲欧美aaaa| 欧美激情18p| 日韩精品视频在线| 亚洲www永久成人夜色| 成人精品视频99在线观看免费| 亚洲偷熟乱区亚洲香蕉av| 久久久国产精品免费| 国产精品成人观看视频国产奇米| 欧美日韩亚洲一区二区| 日韩中文字幕在线免费观看| 久久精品成人欧美大片| 欧美—级a级欧美特级ar全黄| 日韩高清不卡av| 久久国产一区二区三区| 在线观看欧美日韩| 久久精品视频亚洲| 亚洲美女性视频| 日韩成人网免费视频| 亚洲欧美精品一区| 欧美极品第一页| 欧美乱大交做爰xxxⅹ性3| 欧美成人第一页| 久久成人综合视频| 亚洲自拍偷拍一区| 国产日韩精品在线观看| 久久精品视频在线| 欧美性色视频在线| 欧美日韩另类字幕中文| 国产精品ⅴa在线观看h| 欧美国产日本高清在线| 欧美成人中文字幕在线| 国产欧美日韩精品在线观看| 日韩免费高清在线观看| 欧美资源在线观看| 久久免费成人精品视频| 欧美疯狂做受xxxx高潮| 亚洲直播在线一区| 欧美二区乱c黑人| 欧美日韩在线视频首页| 国产日韩欧美一二三区| 在线看国产精品| 伊人精品在线观看| 亚洲高清av在线| 日韩免费电影在线观看| 国产精品扒开腿爽爽爽视频| 日韩在线视频免费观看高清中文| 亚洲免费高清视频| 成人网欧美在线视频| 日韩视频在线免费观看| 97视频在线看| 欧美电影电视剧在线观看| 黄色成人在线免费| 青青草一区二区| 欧美激情奇米色| 亚洲国产精品va| 国内精品美女av在线播放| 成人福利免费观看| 国产视频精品xxxx| 国产精品香蕉国产| 久久久精品2019中文字幕神马| 亚洲精品欧美日韩| 91免费看视频.| 在线视频免费一区二区| 国产精品高潮视频| 亚洲一区二区三区四区在线播放| 久久不射热爱视频精品| 欧美日韩福利电影| 成人精品一区二区三区电影免费| 国产成人精品免费视频| 日韩天堂在线视频|