ASP.NET WebAPI导出CSV
更新时间:2022年05月04日 15:35:14 作者:農碼一生
这篇文章介绍了ASP.NET WebAPI导出CSV的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
一、JS脚本
window.open("../Ticket/ExportTicket");二、后台实现代码
[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的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
IIS处理Asp.net请求和Asp.net页面生命周期说明
当一个客户端页面访问IIS试图获取一些信息的时候,发生了什么事情?一个请求在通过了HTTP管道后又发生了什么?本文主要是描述这两个过程,即IIS处理asp.net请求和asp.net的页面生命周期。欢迎大家积极拍砖,共同学习,共同进步。2011-05-05
ASP.NET GridView的Bootstrap分页样式
这篇文章主要为大家详细介绍了ASP.NET GridView的Bootstrap分页样式,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2016-11-11
用javascript css实现GridView行背景色交替、鼠标划过行变色,点击行变色选中
前几天在博问里发现有人问关于 GridView点击行变色 的问题,突然想起很久很久以前,写过一篇文章 一个简单但常用的表格样式--鼠标划过行变色--简洁实现 ,是关于表格行颜色交替和鼠标指向时变色的,正好今天把那一篇补充和扩展一下2008-09-09
asp.net中引用同一个项目中的类库 避免goToDefinition时不能到达真正的定义类
asp.net中引用同一个项目中的类库 避免 goToDefinition时不能到达真正的定义类2011-10-10
asp.net Web Service 接口大量数据传输解决方案
就管他叫“使用多线程分段获取大量数据方法”吧。假定我们的需求是,通过Web Service获取10W条订单,我的解决方案是 分成10个线程每个线程传输1W条订单分段获取2010-04-04
.NET SkiaSharp 生成二维码验证码及指定区域截取方法实现
这篇文章主要为大家介绍了.NET SkiaSharp 生成二维码验证码及指定区域截取方法实现详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2022-10-10
ASP.NET MVC使用RazorEngine解析模板生成静态页
这篇文章主要介绍了ASP.NET MVC使用RazorEngine解析模板生成静态页的相关资料,需要的朋友可以参考下2016-05-05


最新评论