前台: <asp:Button ID="btndao" runat="server"  Text="导出excel文件" onclick="btndao_Click"></asp:Button>

。cs:
protected void btndao_Click(object sender, EventArgs e)
    {
        this.ExportExcel();
    }
    /// <summary>
    /// 导出数据到Ecxc
    /// </summary>
    private void ExportExcel()
    {
        using (aosmithnewEntities db = new aosmithnewEntities())
        {
            List<ReservationForm> formlist = db.ReservationForm.OrderBy(o => o.States).ThenByDescending(o => o.AddTime).ToList();
            string SavaFilesPath = globalVariables.Download + Guid.NewGuid() + ".xls";
            if (formlist == null || formlist.Count == 0)
            {
                throw new Exception("没有数据可导出。");
            }
            //建立一个Excel进程 Application
            Application excelApplication = new Application();             //默认值为 True。如果不想在宏运行时被无穷无尽的提示和警告消息所困扰,请将本属性设置为 False;这样每次出现需用户应答的消息时,Microsoft Excel
            // 将选择默认应答。
            //如果将该属性设置为 False,则在代码运行结束后,Micorosoft Excel 将该属性设置为 True,除非正运行交叉处理代码。
            //如果使用工作簿的 SaveAs 方法覆盖现有文件,“覆盖”警告默认为“No”,当 DisplayAlerts 属性值设置为 True 时,Excel 选择“Yes”。
            excelApplication.DisplayAlerts = false;             //  建立或打开一个 Workbook对象生成新Workbook
            Workbook workbook = excelApplication.Workbooks.Add(Missing.Value);
            int i = 2;
            Worksheet lastWorksheet = (Worksheet)workbook.Worksheets.get_Item(workbook.Worksheets.Count);
            Worksheet newSheet = (Worksheet)workbook.Worksheets.Add(Type.Missing, lastWorksheet, Type.Missing, Type.Missing);
            newSheet.Cells[1, 1] = "产品类型";
            newSheet.Cells[1, 2] = "型号";
            newSheet.Cells[1, 3] = "安装/维保";
            newSheet.Cells[1, 4] = "问题描述";
            newSheet.Cells[1, 5] = "手机";
            newSheet.Cells[1, 6] = "其他联系方式";
            newSheet.Cells[1, 7] = "联系人姓名";
            newSheet.Cells[1, 8] = "省份";
            newSheet.Cells[1, 9] = "城市";
            newSheet.Cells[1, 10] = "城(区)县";
            newSheet.Cells[1, 11] = "详细地址";
            newSheet.Cells[1, 12] = "上门时间";
            newSheet.Cells[1, 13] = "其他要求";
            newSheet.Cells[1, 14] = "表单状态";
            ((Range)newSheet.Rows.get_Item(1)).Font.Bold = true;
            foreach (var dt in formlist)
            {
                //DateTime dtime = DateTime.Now;
                newSheet.Cells[i, 1] = dt.ProductCategoryName;
                newSheet.Cells[i, 2] = dt.Model;
                newSheet.Cells[i, 3] = dt.FormName;
                newSheet.Cells[i, 4] = dt.Description;
                newSheet.Cells[i, 5] = dt.Mobile;
                newSheet.Cells[i, 6] = dt.TelPhone;
                newSheet.Cells[i, 7] = dt.ContactsName;
                newSheet.Cells[i, 8] = dt.ProvinceName;
                newSheet.Cells[i, 9] = dt.CityName;
                newSheet.Cells[i, 10] = dt.DistrictName;
                newSheet.Cells[i, 11] = dt.Address;
                newSheet.Cells[i, 12] = dt.ServicesTime;
                newSheet.Cells[i, 13] = dt.Other;
                if (int.Parse(dt.States.ToString()) != 0)
                {
                    newSheet.Cells[i, 14] = "已处理";                 }
                else 
                {
                    newSheet.Cells[i, 14] = "未处理";
                }
                i++;
            }
            newSheet.Cells.Columns.AutoFit();
            //删除原来的空Sheet
            ((Worksheet)workbook.Worksheets.get_Item(1)).Delete();
            ((Worksheet)workbook.Worksheets.get_Item(1)).Delete();
            ((Worksheet)workbook.Worksheets.get_Item(1)).Delete();
            //设置默认选中是第一个Sheet 类似于Select();
            ((Worksheet)workbook.Worksheets.get_Item(1)).Activate();
            try
            {
                workbook.Close(true, SavaFilesPath, Missing.Value);
            }
            catch (Exception e)
            {
                throw e;
            }
            UploadExcel(SavaFilesPath, true);
            excelApplication.Quit();
        }
    }
    /// <summary>
    /// 提供下载
    /// </summary>
    /// <param name="path"></param>
    /// <param name="page"></param>
    ///  <param name="isDelete"></param>
    private static void UploadExcel(string path, bool isDelete)
    {
        FileInfo file = new FileInfo(path);
        HttpContext.Current.Response.Clear();
        HttpContext.Current.Response.Charset = "GB2312";
        HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.UTF8;
        // 添加头信息,为"文件下载/另存为"对话框指定默认文件名
        HttpContext.Current.Response.AddHeader("Content-Disposition", "attachment; filename=" + HttpUtility.UrlEncode(file.Name));
        // 添加头信息,指定文件大小,让浏览器能够显示下载进度
        HttpContext.Current.Response.AddHeader("Content-Length", file.Length.ToString());
        // 指定返回的是一个不能被客户端读取的流,必须被下载
        HttpContext.Current.Response.ContentType = "application/ms-excel";
        // 把文件流发送到客户端
        HttpContext.Current.Response.WriteFile(file.FullName);
        HttpContext.Current.Response.Flush();
        if (isDelete)
        {
            File.Delete(path);
        }
        // 停止页面的执行
        HttpContext.Current.Response.End();     }
												

导出excel表功能的更多相关文章

  1. 传参导出Excel表乱码问题解决方法

    业务场景 先描述一下业务场景,要实现的功能是通过搜索框填写参数,然后点击按钮搜索数据,将搜索框的查询参数获取,附加在链接后面,调导Excel表接口,然后实现导出Excel功能.其实做导Excel表功能 ...

  2. thinkphp导入导出excel表单数据

    在PHP项目经常要导入导出Excel表单. 先去下载PHPExcel类库文件,放到相应位置. 我在thinkphp框架中的位置为ThinkPHP/Library/Org/Util/ 导入 在页面上传e ...

  3. 【ITOO 1】将List数据导出Excel表

    需求描述:在课表导入的时候,首先给用户提供模板(excel),然后将用户填写好的数据读取到list集合中.再进行判空处赋值处理,以及去重处理.这篇博客,主要介绍读取excel表和导出excel表的方法 ...

  4. ASP.NET导出excel表方法汇总

    asp.net里导出excel表方法汇总  1.由dataset生成 public void CreateExcel(DataSet ds,string typeid,string FileName) ...

  5. DateGridew导出Excel表+常见错误提示

    在敲机房收费系统的时候,显示数据的时候需要将DateGridew 中的数据导出进Excel表.DateGridew导出Excel表是比较常见的,当然导出Excel表有很多种方法,下面是个人认为比较容易 ...

  6. 前端导出excel表

    前端导出excel表 方式一: 前端js实现 : https://www.cnblogs.com/zhangym118/p/6235801.html 方式二: java后端实现: https://bl ...

  7. C# asp.net中导出Excel表时总出现"只能在执行 Render() 的过程中调用 RegisterForEventValidation

    C# asp.net中导出Excel表时总出现"只能在执行 Render() 的过程中调用 RegisterForEventValidation 后台添加以下方法:/// <summa ...

  8. vue+element UI如何导出excel表

    导出excel表应按如下规则 首先要先安装如下依赖 npm install --save xlsx npm install --save file-saver 接下在在你的代码中去引用这两个 impo ...

  9. 微擎 人人商城 导出excel表分析

    在 数据处理上 ,有很多时候需要导出excel表  来当报表, 等 ,  php  人人商城导出报表过程简单分析 在导出时候发现 ca('statistics.order.export'); 出于好奇 ...

随机推荐

  1. java获取数据库的列名,类型等信息

    当你使用和学习JDK的时候,可以查看并学习它所提供给你的两个ResultSetMetaData 和DataBaseMetaData类的源码并很好的了解它们的实现原理和思路,JDBC中提供有两种源数据, ...

  2. 第2章 Posix IPC

    2.1 概述 Poxix IPC包含:Posix消息队列.Posix信号量.Posix共享内存 2.2 IPC名字 Posix 消息队列.Posix信号量.Posix共享内存这三种Posix IPC都 ...

  3. RDLC添加页码

    页脚显示页码并总页数首先添加页脚,在页脚拖一textbox,textbox的表达式输入:="第" & Globals!PageNumber & "页 共& ...

  4. Delphi中自画TStatusBar面板中的文字颜色背景以及图片

    转自 http://www.delphitop.com/html/kongjian/351.html 首先定义:procedure TStatusForm.FormCreate(Sender: TOb ...

  5. arm交叉编译器gnueabi、none-eabi、arm-eabi、gnueabihf、gnueabi区别

    命名规则 交叉编译工具链的命名规则为:arch [-vendor] [-os] [-(gnu)eabi] arch – 体系架构,如ARM,MIPSvendor – 工具链提供商os – 目标操作系统 ...

  6. Zookeeper分布式协调服务

    1.zookeeper是一个分布式协调的服务. 2.安装zookeeper的软件的机器,我们称之为zk server 3.zk里面的角色有leader.follower.observer,注意只有一个 ...

  7. 带你快速了解CODESOFT 2015

    CODESOFT是知名的条码标签设计打印软件,现在又推出了最新版CODESOFT 2015,其新功能.大改进让人为之一振.下面跟随小编的脚步,走进CODESOFT 2015,看一看CODESOFT 2 ...

  8. JAVA+PHP+阿里云组件纯手工实现POP、SMTP、IMAP开发邮件服务器(二)

    java开发邮件服务器的接收模块 用java建立socket服务端,监听端口25,实现SMTP协议.即可完成邮件服务器的接收模块. 这里要注意的是,SMTP协议其实可以分为两种.一种是你用手机.PC等 ...

  9. 慕课网-安卓工程师初养成-1-5 使用Eclipse开发Java程序

    来源: http://www.imooc.com/video/1412 eclipse --- IDE 集成开发环境(IDE)是一类软件 将程序开发环境和程序调试环境集合在一起,提高开发效率 其他ID ...

  10. memcached学习(二)

    Slab Allocation机制:整理内存以便重复使用 最近的memcached默认情况下采用了名为Slab Allocator的机制分配.管理内存. 在该机制出现以前,内存的分配是通过对所有记录简 ...