excel 导入 与 导出
Excel导入
public ActionResult Excel(HttpPostedFileBase file)
{
HttpPostedFileBase files = file;//接收客户端传递过来的数据.
try
{
if (files == null)
{
return Content("请选择上传的Excel文件");
}
else
{
file.SaveAs(Server.MapPath("~/UploadFile/Excel/" + file.FileName));
//对文件的格式判断,此处省略
AltasEntities db = new AltasEntities();//EF上下文对象
Stream inputStream = files.InputStream;
IWorkbook workbook;
string fileExt = Path.GetExtension(files.FileName);
if (fileExt == ".xls")
{
workbook = new HSSFWorkbook(inputStream);
}
else if (fileExt == ".xlsx")
{
workbook = new XSSFWorkbook(inputStream);
}
else
{
return null;
}
NPOI.SS.UserModel.ISheet sheet = workbook.GetSheetAt(0);
int rowCount = sheet.LastRowNum + 1;
for (int i = (sheet.FirstRowNum + 1); i <= rowCount - 1; i++)
{
IRow row = sheet.GetRow(i);
Equiemints model = new Equiemints();
if (row != null)
{
if (row.GetCell(0) != null)
{
model.EquiemintId = GetCellValue(row.GetCell(0)).ToUpper();
}
if (row.GetCell(1) != null)
{
model.Company = GetCellValue(row.GetCell(1));
}
if (row.GetCell(2) != null)
{
model.ModelsType = GetCellValue(row.GetCell(2));
}
if (row.GetCell(3) != null)
{
model.OpenCreatetime = DateTime.Parse(GetCellValue(row.GetCell(3)));
}
if (row.GetCell(4) != null)
{
model.ZBType = GetCellValue(row.GetCell(4));
}
if (row.GetCell(5) != null)
{
model.ZBEndCreatetime = DateTime.Parse(GetCellValue(row.GetCell(5)));
//model.SalesName = GetCellValue(row.GetCell(5));
}
if (row.GetCell(6) != null)
{
model.a1 = GetCellValue(row.GetCell(6));
}
if (row.GetCell(7) != null)
{
model.a2 = GetCellValue(row.GetCell(7));
}
if (row.GetCell(8) != null)
{
model.a3 = GetCellValue(row.GetCell(8));
}
if (row.GetCell(9) != null)
{
model.a4 = GetCellValue(row.GetCell(9));
}
if (row.GetCell(10) != null)
{
model.a5 = GetCellValue(row.GetCell(10));
}
}
db.Equiemints.Add(model);
}
db.SaveChanges();
return Content("<script>alert('导入成功!',location.href='/Equiemints/Index');</script>");
}
}
catch (Exception)
{
return Content("<script>alert('导入失败!');</script>");
}
}
/// <summary>
/// 根据Excel列类型获取列的值
/// </summary>
/// <param name="cell">Excel列</param>
/// <returns></returns>
private static string GetCellValue(ICell cell)
{
if (cell == null)
return string.Empty;
switch (cell.CellType)
{
case CellType.Blank:
return string.Empty;
case CellType.Boolean:
return cell.BooleanCellValue.ToString();
case CellType.Error:
return cell.ErrorCellValue.ToString();
case CellType.Numeric:
case CellType.Unknown:
default:
return cell.ToString();
case CellType.String:
return cell.StringCellValue;
case CellType.Formula:
try
{
HSSFFormulaEvaluator e = new HSSFFormulaEvaluator(cell.Sheet.Workbook);
e.EvaluateInCell(cell);
return cell.ToString();
}
catch
{
return cell.NumericCellValue.ToString();
}
}
}
Excel导出
public ActionResult DcExcel(List<int> id)
{
var db = new AltasEntities();
if (id == null)
{
id = db.Equiemints.Select(s => s.Id).ToList();
}
string filename = DateTime.Now.ToString("yyyyMMddHHmmss") + ".csv";
string path = Server.MapPath("/UploadFile/" + filename);
FileInfo fi = new FileInfo(path);
using (StreamWriter sw = fi.CreateText())
{
sw.WriteLine("设备序号,所属公司,机型,开始时间,质保类型,结束时间,服务销售,是否绑定,字段1,字段2,字段3");
foreach (int i in id)
{
//找到要导出的数据
var saa = db.Equiemints.Find(i);
if (saa.a1==null)
{
saa.a1 = "无";
}
if (saa.a2 == null)
{
saa.a2 = "无";
}
if (saa.a3 == null)
{
saa.a3 = "无";
}
sw.WriteLine(
saa.EquiemintId.ToString()
+ "," + saa.Company.ToString()
+ "," + saa.ModelsType.ToString()
+ "," + saa.OpenCreatetime.ToString()
+ "," + saa.ZBType.ToString()
+ "," + saa.ZBEndCreatetime.ToString()
+ "," + saa.uname.ToString()
+ "," + saa.bangname.ToString()
+ "," + saa.a1.ToString()
+ "," + saa.a2.ToString()
+ "," + saa.a3.ToString()
);
}
sw.Close();
}
var name = Path.GetFileName(path);
return File(path, "application/x-zip-compressed", name);
}
excel 导入 与 导出的更多相关文章
- C# Excel导入、导出【源码下载】
本篇主要介绍C#的Excel导入.导出. 目录 1. 介绍:描述第三方类库NPOI以及Excel结构 2. Excel导入:介绍C#如何调用NPOI进行Excel导入,包含:流程图.NOPI以及C#代 ...
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(63)-Excel导入和导出-自定义表模导入
系列目录 前言 上一节使用了LinqToExcel和CloseXML对Excel表进行导入和导出的简单操作,大家可以跳转到上一节查看: ASP.NET MVC5+EF6+EasyUI 后台管理系统(6 ...
- C# Excel导入、导出
本篇主要介绍C#的Excel导入.导出. 目录 1. 介绍:描述第三方类库NPOI以及Excel结构 2. Excel导入:介绍C#如何调用NPOI进行Excel导入,包含:流程图.NOPI以及C#代 ...
- JXLS (Excel导入、导出工具使用)
JXLS (Excel导入.导出工具使用) 1:简介: jxls是一个简单的.轻量级的excel导出库,使用特定的标记在excel模板文件中来定义输出格式和布局.java中成熟的excel导出工具有p ...
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(63)-Excel导入和导出
系列目录 昨天文章太过仓促没有补充导出的示例源码,在者当时弄到到很晚没时间做出导出功能,对阅读理解造成影响,现补充一份示例源码,顺便补充导出的功能说明,望理解 示例代码下载 https://yun ...
- winform之excel导入和导出
引用命名空间 using Microsoft.Office.Interop.Excel;DataGridView 导出到Excel public static void SaveAs(DataGr ...
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(87)-MVC Excel导入和导出
本文示例代码下载: 链接:http://pan.baidu.com/s/1jHBdgCA 密码:hzh7 ps:Vs数据库脚本在解压目录下,修改web.config数据库链接,示例代码包含:导入,导出 ...
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(88)-Excel导入和导出-自定义表模导出
前言 之前说了导入和导出,也提供了自定义的表模的导入,可见LinqToExcel可以做的事情不仅仅如此 这次我们来演示比较复杂的导出Excel,导出复杂的Excel与导入复杂的Excel原理基本是一样 ...
- c# excel 导入 与 导出(可直接用)
c#操作excel方式很多 采用OleDB读取EXCEL文件: 引用的com组件:Microsoft.Office.Interop.Excel.dll 读取EXCEL文件 将EXCEL文件转化成C ...
随机推荐
- Asycn/Await 异步编程初窥(二)
经过总过4天的学习和实践,做完了 WinForm 下 .Net 4.5 的基本异步应用,实现了一个 Http 协议下载的测试程序,为以后使用 .Net 4.5 积累知识和经验.这个小程序完成这样几个作 ...
- [转] iOS ABI Function Call Guide
source: apple ARMv6 Function Calling Conventions When functions (routines) call other functions (sub ...
- c语言,递归翻转一个单链表,c实现单链表
目的:主要是练习c里面单链表的实现,递归思想复习; #include <stdlib.h> #include <stdio.h> typedef struct _Node{// ...
- urllib2 源码小剖
urllib2 源码小剖 2013-08-25 23:38 by 捣乱小子, 272 阅读, 0 评论, 收藏, 编辑 两篇小剖已经完成: urllib 源码小剖 urllib2 源码小剖 urlli ...
- Linq 结果转成 json
public string BindGrid(string page,string rows) { int pageIndex = 0; if ...
- 在.NET Framework对于JSON本来就提供了很好的支持
1. 使用JavaScriptSerializer,位于命名空间System.Web.Script.Serialization,使用: 序列化为JSON字符串: Code }; JavaScriptS ...
- Window Service 计划任务
在ASP.NET中创建计划任务,就我个人而言,用过两种方式,一种是用SQL Server创建,把写好的SSIS包导入SQL Server创建的任务中,设置好时间让它去执行.还有一种就是利用window ...
- ASP.NET Web API的消息处理管道: HttpRoutingDispatcher
ASP.NET Web API的消息处理管道: HttpRoutingDispatcher 认情况下,作为消息处理管道“龙头”的HttpServer的Dispatcher属性返回一个HttpRouti ...
- sharepoint 2013 自定义列表eventhandle权限控制
记录一下如何在sharepoint server 2013自定义列表中,使用eventhandle控制自定义列表custom list的条目item权限. ///<summary> /// ...
- are both mapped to the url-pattern 错误解决方法
今天运行tomcat的时候出现报了一大波错误,下面我截取了部分错误信息: 严重:A child container failed during start java.util.concurrent.E ...