zoukankan      html  css  js  c++  java
  • epplus excel数据导出(数据量有点大的情况) Web和Client

    Asp.net MVC后台代码 
    public ActionResult Export() { OfficeOpenXml.ExcelPackage ep = new OfficeOpenXml.ExcelPackage(); OfficeOpenXml.ExcelWorkbook wb = ep.Workbook; OfficeOpenXml.ExcelWorksheet ws = wb.Worksheets.Add("我的工作表"); ////配置文件属性 //wb.Properties.Category = "类别"; //wb.Properties.Author = "作者"; //wb.Properties.Comments = "备注"; //wb.Properties.Company = "公司"; //wb.Properties.Keywords = "关键字"; //wb.Properties.Manager = "管理者"; //wb.Properties.Status = "内容状态"; //wb.Properties.Subject = "主题"; //wb.Properties.Title = "标题"; //wb.Properties.LastModifiedBy = "最后一次保存者"; // var list = GetList(); int x = 0; for (int i = 0; i < 300000; i++) { //if (x == 1000000) //{ // ws = wb.Worksheets.Add("我的工作表" + Guid.NewGuid().ToString()); // x = 0; //} for (int j = 1; j <= 9; j++) { ws.Cells[(x + 1), j].Value = DateTime.Now.ToString(); } x++; } //写数据 //ws.Cells[1, 1].Value = "Hello"; //ws.Cells[1, 1].Style.Numberformat.Format = "yyyy-MM-dd"; //ws.Column(1).Width = 40;//修改列宽 //ws.Cells["B1"].Value = "World"; //ws.Cells[3, 3, 3, 5].Merge = true; //ws.Cells[3, 3].Value = "Cells[3, 3, 3, 5]合并"; //ws.Cells["A4:D5"].Merge = true; //ws.Cells["A4:D5"].Style.HorizontalAlignment = OfficeOpenXml.Style.ExcelHorizontalAlignment.Center;//居中 //ws.Cells["A4"].Value = "Cells["A4:D5"]合并"; //写到客户端(下载) Response.Clear(); Response.AddHeader("content-disposition", "attachment; filename=FileFlow.xlsx"); Response.ContentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"; byte[] data=ep.GetAsByteArray(); Response.AddHeader("Content-Length", data.Length.ToString()); Response.BinaryWrite(data); //ep.SaveAs(Response.OutputStream); 第二种方式 Response.Flush(); Response.End(); return null; }
     FileInfo newFile = new FileInfo(@"d:	est.xlsx");
                if (newFile.Exists)
                {
                    newFile.Delete();
                    newFile = new FileInfo(@"d:	est.xlsx");
                }
                //using (ExcelPackage package = new ExcelPackage(newFile))
                //{
                //    ExcelWorksheet worksheet = package.Workbook.Worksheets.Add("test");
                //    worksheet.Cells[1, 1].Value = "名称";
                //    worksheet.Cells[1, 2].Value = "价格";
                //    worksheet.Cells[1, 3].Value = "销量";
    
                //    worksheet.Cells[2, 1].Value = "大米";
                //    worksheet.Cells[2, 2].Value = 56;
                //    worksheet.Cells[2, 3].Value = 100;
    
                //    worksheet.Cells[3, 1].Value = "玉米";
                //    worksheet.Cells[3, 2].Value = 45;
                //    worksheet.Cells[3, 3].Value = 150;
    
                //    worksheet.Cells[4, 1].Value = "小米";
                //    worksheet.Cells[4, 2].Value = 38;
                //    worksheet.Cells[4, 3].Value = 130;
    
                //    worksheet.Cells[5, 1].Value = "糯米";
                //    worksheet.Cells[5, 2].Value = 22;
                //    worksheet.Cells[5, 3].Value = 200;
    
                //    package.Save();
                //}
                OfficeOpenXml.ExcelPackage ep = new OfficeOpenXml.ExcelPackage(newFile);
                OfficeOpenXml.ExcelWorkbook wb = ep.Workbook;
                OfficeOpenXml.ExcelWorksheet ws = wb.Worksheets.Add("我的工作表");
                //配置文件属性
                //wb.Properties.Category = "类别";
                //wb.Properties.Author = "作者";
                //wb.Properties.Comments = "备注";
                //wb.Properties.Company = "公司";
                //wb.Properties.Keywords = "关键字";
                //wb.Properties.Manager = "管理者";
                //wb.Properties.Status = "内容状态";
                //wb.Properties.Subject = "主题";
                //wb.Properties.Title = "标题";
                //wb.Properties.LastModifiedBy = "最后一次保存者";
                // var list = GetList();
                int x = 0;
                for (int i = 0; i < 100; i++)
                {
                    if (x == 1000000)
                    {
                        ws = wb.Worksheets.Add("我的工作表" + Guid.NewGuid().ToString());
                        x = 0;
    
                    }
                    for (int j = 1; j <= 2; j++)
                    {
    
                        ws.Cells[(x + 1), j].Value = DateTime.Now.ToString();
                        Console.WriteLine((i+1));
                    }
                    x++;
    
                }
                ep.Save();

    Client的版本亲测至少可导出千万级别的数据,Web版本要看服务器内存配置。。

    epplus下载路径: http://epplus.codeplex.com/

  • 相关阅读:
    关于hive开窗函数的问题
    MFC三种不同方式实现图形的保存和重绘---方法一:通过集合类CPtrArray保存点的坐标
    win8 安装VC++ 6.0 出现错误的解决方法
    在数组中进行二分查找找出某数在数组中的下标
    编写自定义的字符串一致性匹配方法,只要两个字符串包含同样的字符, 不管字符的顺序如何,都认为两个字符串一致,如:”aabbcc”和”abcabc”被认为是一致的
    若干个数 以“字符串形式‘从键盘输入,将其转换为 double 型,并求平均数
    使用IO技术,创建一个目录,然后复制一个文件到该目录!实现复制的功能。(在博客园上传的第一份代码)
    easyui datagrid editor可选type
    MVC统计在线人数
    替换SQL字段中的换行符,回车符
  • 原文地址:https://www.cnblogs.com/gaocong/p/5133609.html
Copyright © 2011-2022 走看看