后台代码

public void ToExcel(){

//第一步:获取模版文件物理路径

string file_0 = Server.MapPath("/Content/Excel/ExportExcel.xlsx");

//第二步:定义输入流

FileStream stream_0 = new FileStream(file_0, FileMode.Open, FileAccess.Read);

//第三步:判断模版excel文件的版本,创建工作簿

IWorkbook book = null;

if (file_0.IndexOf(".xlsx") > 0){

book = new XSSFWorkbook(stream_0);

}else if (file_0.IndexOf(".xls") > 0){

book = new HSSFWorkbook(stream_0);

}

//第四步:创建工作簿sheet页

ISheet sheet = book.GetSheet("Sheet1");

//第五步:遍历数据导入工作簿

for (int i = 1; i < list.Count; i++) {//list是数据源,可以是dt,也可以是List<>,可以自己写方法获取,调用datagrid的方法,也可以利用session(导出当前页时)

//(int等数据类型)this.HttpContent.Session["key"] = value;

IRow row = sheet.CreateRow(i);

row.CreateCell(0).SetCellValue("测试");

row.CreateCell(1).SetCellValue("测试");

row.CreateCell(1).SetCellValue(dd);//若dd是dateTime类型的数据则导出到excel表格时只显示一个数值,需要做如下转换

//dd.ToString("yyyy-mm-dd hh:mm:ss") ,转换后插入表格则显示指定的格式

}

//第六步:定义输出流,将工作簿写到输出流

string file_1 = Server.MapPath("/Content/Excel/downExcel.xlsx");

//.xls格式的excel可以加扩展名.xls,但.xlsx格式的加上扩展名会报错。

//扩展名.xls时,可以在服务器预先设置下载模板,字段的格式都可以在下载模板中设置并会应用到下载后的excel中

//扩展名为.xlsx时,无法预先设置下载模板,下载下来打不开;要求此处定义的路径不存在,执行时会自动创建,可以避免前面提到的错误。

//但因此会在服务器新建一个downExcel.xlsx文件,为了避免以后导出出错,需要及时删除

//if (System.IO.File.Exists(file_1))  { System.IO.File.Delete(file_1);}

using (FileStream stream_1 = System.IO.File.OpenWrite(file_1)){

book.Write(stream_1);

}

//第七步:写入客户端

System.IO.FileInfo filet = new System.IO.FileInfo(file_1);

Response.Clear();

Response.Charset = "GB2312";

Response.ContentEncoding = System.Text.Encoding.UTF8;

// 添加头信息,为"文件下载/另存为"对话框指定默认文件名

if (file_0.IndexOf(".xlsx") > 0){

Response.AddHeader("Content-Disposition", "attachment; filename=" + Server.UrlEncode("订单详情.xlsx"));

}else if (file_0.IndexOf(".xls") > 0){

Response.AddHeader("Content-Disposition", "attachment; filename=" + Server.UrlEncode("订单详情.xls"));

}  //当excel是.xls类型时可以正常发挥作用,但xlsx则不行。Server.UrlEncode采用utf-编码,除文字外数字字母均可以,文字会显示一串乱码。

绿色部分也可以改为: Response.AddHeader("Content-Disposition", "attachment; filename=" + Server.UrlEncode(""));此时默认文件名为方法名

若非要显示指定文字: Response.AddHeader("Content-Disposition", "attachment; filename=默认文件名.xlsx");此时.xlsx不会显示出来,是扩展名

// 添加头信息,指定文件大小,让浏览器能够显示下载进度

Response.AddHeader("Content-Length", filet.Length.ToString());

// 指定返回的是一个不能被客户端读取的流,必须被下载

Response.ContentType = "application/ms-excel";

// 把文件流发送到客户端

Response.WriteFile(filet.FullName);

// 停止页面的执行

Response.End();

if (System.IO.File.Exists(file_1))
      {
         System.IO.File.Delete(file_1);
      }
      stream_0.Close();

}

注意:--ExportExcel.xls是模版文件;downExcel.xls是下载文件(扩展名为.xlsx,一定不能存在);

--执行程序过程中会把创建的excel工作簿写入downExcel.xls里面,在根据downExcel.xls的物理路径写入客户端提供下载

导出excel-模版的更多相关文章

  1. 导出excel模版

    方法一: public void ToExcel(){ //第一步:获取模版物理路径 string file_1 = Server.MapPath("/Content/Excel/downE ...

  2. JAVA实现Excel导出数据(以写好的Excel模版导出)

    工作中经常会有将后台数据以Excel导出的功能. 简单的方法有将response的contentType设置为application/vnd.ms-excel: 或在JSP页面直接设置成: <% ...

  3. jxls使用模版导出Excel

    /**     * 使用模版导出Excel     */    @SuppressWarnings({ "unchecked", "deprecation" } ...

  4. java+jxls利用excel模版进行导出

    大多时候会出现需要导出excel的功能,利用poi可以实现简单的导出,可以说poi的功能非常强大可以做到细节的定制化操作,但相对于在office操作excel,利用poi完全生成excel会显得非常复 ...

  5. 按模版导出Excel

    实现效果: excel模版: ExcelHandle.java package com.common.utils; import java.io.File; import java.io.FileIn ...

  6. [poi使用]使用excel模版导出excel

    ​ Apache POI是基于Office Open XML标准(OOXML)和Microsoft的OLE 2复合文档格式(OLE2)处理各种文件格式的开源项目.简而言之,您可以使用Java读写MS ...

  7. POI3.10 根据Excel模版导出数据测试

    1:所需jar包 2:Mysql数据库表内容如下: 3:代码结构如下: (1)User.java public class User { private int id; private String ...

  8. 导出Excel(导出一个模版)

    有时,客户需要一个标准的模板来填东西,然后在导入 这时可以弄好excel模板,供导出 /** * 导出excel模板文件 * @param request * @param response * @r ...

  9. 利用poi导出Excel

    import java.lang.reflect.Field;import java.lang.reflect.InvocationTargetException;import java.lang.r ...

  10. Java报表工具FineReport导出EXCEL的四种API

    在实际的应用中会经常需要将数据导出成excel,导出的方式除原样导出还有分页导出.分页分sheet导出和大数据量导出.对于excel 2003版,由于限制了每个sheet的最大行数和列数,大数据量导出 ...

随机推荐

  1. idea 远程代码调试

    声明一点:重要的事情说3遍 本地代码和服务器代码必须一致 本地代码和服务器代码必须一致 本地代码和服务器代码必须一致 第一步,创建remote 第二步.填写服务器信息 第三部.tomcat/bin/s ...

  2. ajax 415

    ajax 发送post请求是出现415错误,是ajax的格式有问题,如下. $.ajax({ type: 'POST', url: '/login', data: { "username&q ...

  3. python文件夹中pycache文件是什么

    python(pycache文件的问题):python属于脚本语言,执行python文件需要通过python解释器将源码转换为字节码,然后供cpu读取,pycache文件夹里面保存的就是py文件对应的 ...

  4. [SQL Server创建视图时的注意点]

    创建视图的查询语句必须要遵守一定的限制 1. 要对某些列取别名,并保证列名的唯一 (具有相同的列名的表,在创建视图的时候,需要使用别名,表名.列名 也是不可以的) 当我们在通过新建视图来创建视图的话, ...

  5. [go]new和make开辟内存

    var申明取址和new效果一样 值类型 引用类型 make和new的区别 内置函数new按指定类型长度分配零值内存,返回指针,并不关心类型内部构造和初始化方式. 而引用类型则必须使用make函数创建, ...

  6. JS方法调用jQuery内部方法

    转载于:https://blog.csdn.net/tsoTeo/article/details/77848932 已经测试过,可以正常调用!!以下为原文: JS方法能不能调用JQuery里面的方法  ...

  7. spring mvc路径匹配原则

    Ant path 匹配原则 在Spring MVC中经常要用到拦截器,在配置需要要拦截的路径时经常用到<mvc:mapping/>子标签,其有一个path属性,它就是用来指定需要拦截的路径 ...

  8. Redis 持久化配置(兼论瞎翻译的问题)

    redis.conf 文件中配置 save 默认配置项: save save save 查了好几个地方都是这么说的: 第一句的意思:15分钟内修改了一个键就保存??? 往 Redis 里加了一个值,重 ...

  9. AutoResetEvent和ManualResetEvent(多线程操作)

    摘自风中灵药的博客:https://www.cnblogs.com/qingyun163/archive/2013/01/05/2846633.html#!comments AutoResetEven ...

  10. C基础知识(10):预处理器

    C预处理器不是编译器的组成部分,但是它是编译过程中一个单独的步骤.简言之,C预处理器只不过是一个文本替换工具而已,它们会指示编译器在实际编译之前完成所需的预处理. 所有的预处理器命令都是以井号(#)开 ...