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 ...
 
随机推荐
- .NET4.5 Console.ReadKey()在多线程下的BUG
			
.NET 4.5 在多线程的控制台里,Console.ReadKey()可能会造成线程死锁.看代码: static void Main(string[] args) { System.Timers.T ...
 - Linux下搭建Nginx+MySQL+PHP
			
在CentOS6.3下实践通过. 1.关闭防火墙 [root@CentOS ~]# chkconfig iptables off 2.关闭selinux vi /etc/sysconfig/selin ...
 - Discuz! X2.5数据库字典(转)
			
DROP TABLE IF EXISTS pre_common_admincp_cmenu; CREATE TABLE pre_common_admincp_cmenu ( `id` SMALLINT ...
 - jQuery实现返回顶部功能
			
整理两个实现功能,一个是右下角的返回顶部,一个是右侧的返回顶部,分别如图 第一种实现 一.JSP或HTML(主体结构) 在body中添加 <body id=" ...
 - 在网络通讯中应用Protobuf
			
在网络通讯中应用Protobuf Protobuf的设计非常适用于在网络通讯中的数据载体,它序列化出来的数据量少再加上以K-V的方式来存储数据,对消息的版本兼容性非常强:还有一个比较大的优点就是有着很 ...
 - Excel 开发概述
			
浅谈Excel开发:一 Excel 开发概述 做Office相关的开发工作快一年多了,在这一年多里,在插件的开发中遇到了各种各样的问题和困难,还好同事们都很厉害,在和他们的交流讨论中学到了很多的知识. ...
 - Union  与 Union all 区别
			
原创,请园长不要删 Sql查询统计时,很多时候用到了union 和 union all,union与union all的区别就是联合查询的时候union会去重,union all不会去重.本人用uni ...
 - C# .Net 使用zxing.dll生成二维码,条形码
			
public static string GetBarcode(string format, string value, int? width, int? height) { ...
 - 使用unity创建塔防游戏(原译)(part1)
			
塔防游戏非常地受欢迎,木有什么能比看着自己的防御毁灭邪恶的入侵者更爽的事了. 在这个包含两部分的教程中,你将使用Unity创建一个塔防游戏. 你将会学到如何: 创建一波一波的敌人 使敌人随着路标移动 ...
 - go语言中sync包和channel机制
			
文章转载至:https://www.bytelang.com/article/content/A4jMIFmobcA= golang中实现并发非常简单,只需在需要并发的函数前面添加关键字"Go&quo ...