ASP.NET WebAPI導出CSV
更新時間:2022年05月04日 15:35:14 作者:農碼一生
這篇文章介紹了ASP.NET WebAPI導出CSV的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
一、JS腳本
window.open("../Ticket/ExportTicket");
二、后臺實現(xiàn)代碼
[HttpGet] public ActionResult ExportTicket(TicketSearch search) { if (search != null) { search.CurrentPage = 1; search.PageSize = 0; } string[] lstTitles = new string[] { "編號", "標題"}; int TotalCount = 0; List<TicketData> lstTicketData = ListTicketEntityToData(search, out TotalCount); List<string[]> lstData = new List<string[]>(); foreach (TicketData itemData in lstTicketData) { string[] data = new string[] { itemData.Barcode, itemData.Label, itemData.SiteId.ToString(), Helper.Htmlhelper.GetSiteInfo(itemData.SiteId), itemData.Owner, string.IsNullOrEmpty(itemData.CardId) ? "" : itemData.CardId, itemData.StartDate == null ? "" : itemData.StartDate.Value.ToString("yyyy-MM-dd HH:mm"), itemData.EndDate == null ? "" : itemData.EndDate.Value.ToString("yyyy-MM-dd HH:mm"), itemData.IsValid.ToString(), itemData.IsUsed.ToString(), itemData.CreateTime.ToString("yyyy-MM-dd HH:mm") }; lstData.Add(data); } string ExportFileName = Helper.ImportExport.ExportData(lstTitles, lstData); return File(new System.IO.FileStream(ExportFileName, System.IO.FileMode.Open), "application/octet-stream", "Ticket" + DateTime.Now.ToString("yyyyMMddHHmmss") + ".csv"); } public static string ExportData(string[] lstTitles, List<string[]> lstData) { try { lock (RunningExport) { string TemplatePath = AppDomain.CurrentDomain.BaseDirectory + "Export"; string FullFileName = AppDomain.CurrentDomain.BaseDirectory + "Export\\template.csv"; if (Directory.Exists(TemplatePath)) { if (File.Exists(FullFileName)) File.Delete(FullFileName); } else { Directory.CreateDirectory(TemplatePath); } if (lstTitles.Length <= 0) { return null; } FileStream fs = new FileStream(FullFileName, FileMode.OpenOrCreate, FileAccess.ReadWrite, FileShare.ReadWrite); StreamWriter sw = new StreamWriter(fs, Encoding.UTF8); string data = ""; foreach (string itemTitle in lstTitles) { data += itemTitle + ","; } sw.WriteLine(data.TrimEnd(',')); foreach (string[] itemData in lstData) { data = ""; foreach (string itemChildData in itemData) { data += itemChildData + ","; } sw.WriteLine(data.TrimEnd(',')); } sw.Close(); fs.Close(); return FullFileName; } } catch (Exception) { return null; } }
到此這篇關于ASP.NET WebAPI導出CSV的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
asp.net SqlHelper數(shù)據(jù)訪問層的使用
如果不使用數(shù)據(jù)訪問層,那么你的代碼里會出現(xiàn)很多SqlConnection、SqlCommand、SqlDataReader、Open、 Close……這些類和方法,而且代碼量很大,讓你不勝其煩,而且代碼寫起來,其實都是體力活,沒有技術含量。2008-09-09.NET中獲取Access新增記錄Id怪現(xiàn)象解決方法
寫了一個函數(shù)獲取Access表中指定用戶Id,要求當傳入的用戶名不存在時,則在表中新增一條記錄并返回Id2012-03-03ASP.NET?MVC使用Boostrap實現(xiàn)產品展示、查詢、排序、分頁
這篇文章介紹了ASP.NET?MVC使用Boostrap實現(xiàn)產品展示、查詢、排序、分頁的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-09-09ASP.NET連接 Access數(shù)據(jù)庫的幾種方法
這篇文章主要介紹了ASP.NET連接 Access數(shù)據(jù)庫的幾種方法,每種方法都非常不錯,具有參考借鑒價值,需要的朋友一起學習吧2016-08-08詳解免費開源的.NET多類型文件解壓縮組件SharpZipLib(.NET組件介紹之七)
本篇文章主要介紹了免費開源的.NET多類型文件解壓縮組件SharpZipLib,這也是一種解壓縮組件,具有一定的參考價值,有興趣的可以了解一下。2016-12-12如何在ASP.NET Core 的任意類中注入Configuration
這篇文章主要介紹了如何在 ASP.NET Core 的任意類中注入Configuration ,幫助大家更好的理解和學習使用.net技術,感興趣的朋友可以了解下2021-04-04