ASP.NET WebAPI导入CSV
更新时间:2022年05月04日 15:36:51 作者:農碼一生
这篇文章介绍了ASP.NET WebAPI导入CSV的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
一、前端代码
<button type="button" class="btn btn-primary" onclick="InportTicket()">导入</button> <input id="fileToUpload" type="file" name="upfile" style="display:none;">
/// JS脚本
$("#fileToUpload").click();
$("#fileToUpload").change(function () {
var formData = new FormData();
formData.append("myfile", document.getElementById("fileToUpload").files[0]);
$.ajax({
url: "../Ticket/TicketFileToUpload",
type: 'POST',
cache: false,
processData: false,
contentType: false,
data: formData,
success: function (res) {
alert(res.Message);
},
error: function (data, status, e) {
alert("操作失败!");
}
})
});二、后台实现代码
[HttpPost]
public ActionResult TicketFileToUpload()
{
try
{
if (Request.Files.Count > 0)
{
HttpPostedFileBase TicketFile = Request.Files[0];
List<string[]> lstData = Helper.ImportExport.InportData(TicketFile.InputStream);
TicketModel ticketope = new TicketModel();
for (int i = 1; i < lstData.Count; i++)
{
string[] itemData = lstData[i];
Ticket entity = ticketope.GetByCode(itemData[0]);
if (entity == null)
{
entity = new Ticket();
entity.Label = itemData[1];
entity.SiteId = int.Parse(itemData[2]);
entity.Owner = itemData[4];
entity.CardId = itemData[5];
entity.StartDate = DateTime.Parse(itemData[6]);
entity.EndDate = DateTime.Parse(itemData[7]);
entity.IsValid = bool.Parse(itemData[8]);
entity.IsUsed = bool.Parse(itemData[9]);
ticketope.Insert(entity);
}
}
return Json(new JsonResultData() { Success = true, Message = "导入数据成功!" });
}
else
{
return Json(new JsonResultData() { Success = false, Message = "找不到导入文件数据!" });
}
}
catch (Exception ex)
{
return Json(new JsonResultData() { Success = false, Message = "导入数据失败!" });
}
}
public static List<string[]> InportData(Stream filestream)
{
lock (RunningInport)
{
List<string[]> lstData = new List<string[]>();
string strLine = "";
bool IsFirst = true;
StreamReader sr = new StreamReader(filestream, Encoding.UTF8);
while ((strLine = sr.ReadLine()) != null)
{
if (IsFirst)
{
string[] strTitles = strLine.Split(',');
lstData.Add(strTitles);
}
else
{
string[] strData = strLine.Split(',');
lstData.Add(strData);
}
}
return lstData;
}
}到此这篇关于ASP.NET WebAPI导入CSV的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
ASP.NET网站管理系统退出 清除浏览器缓存,Session的代码
管理系统退出登陆后,将网址重新输入后还会看到用户登陆后的界面,为了解决这个问题,我采用了以下方法,需要的朋友可以参考下2012-05-05
WCF如何绑定netTcpBinding寄宿到控制台应用程序详解
这篇文章主要给大家介绍了关于WCF如何绑定netTcpBinding寄宿到控制台应用程序的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用WCF具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧2019-07-07


最新评论