.net生成Excel,并下载
生成Excel的方式有很多种,这里记录两个最简单的:
1.将数据保存为html,然后输出到客户端,保存为Excel文件;
2.通过\t\n生成字符串,然后输出到客户端,保存为Excel。
以上两者的原理都是一致的,只是生成的字符串长相不一致而已。我这里使用的是mvc,所以要下载的话,直接生成一个超链接指向当前这个生成文件的Action,用Ajax好像没办法,但是如果当前这个超链接只是请求一个文件,页面也不会刷新,比如一个按钮点击事件:直接windows.location.href="/control/action",如此就可以直接下载,当前页面也不会刷新。
先上共有的代码:
HttpResponseBase resp= HttpContext.Response;
resp.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");//设置编码格式,防止中文乱码
resp.AppendHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode("月报表.xls",Encoding.UTF8));//解决生成的文件名中文乱码
resp.ContentType = "application/ms-excel";
然后是生成数据的过程,这里就分为两种:
1.生成table的html
这里需要获取数据库的数据,然后按自己要的格式生成table,可以对table设置样式之类的,所有对table设置的样式,将会影响生成的Excel,同样可以给table加表头,当然table外面要不要加那些<html>、<body>这些,都不重要,可加可不加,示例如下:
<table border='1'>//设置border=1则生成的表格会有黑色表框
<tr>
<td>1</td><td>2</td><td>3</td><td>4</td>
</tr>
</table>
2.通过\t\n控制Excel样式
在这里,每加一个\t就会生成Excel中的一格,每加一个\n就会换行,这就是原理,所以大家可以拿到数据之后,对数据列表循环,每个数据item是一行
每列数据对应插入到Excel中的一格,示例如下:
foreach (var item in list)
{
ls_item += item.agentName + "\t";
ls_item += item.tourNo + "\t";
ls_item += item.travelerName + "\t";
ls_item += item.checkinDate + "\t";
ls_item += item.checkoutDate + "\t";
ls_item += item.rooms + "\t";
ls_item += item.nights + "\t";
ls_item += item.RoomPrice + "\t";
ls_item += item.minorTotal + "\t\n";//最后加个\n换行
}
以上代码为数据填充的部分,接下来就是将数据输出到客户端,只要两句话:
resp.Write(内容的字符串);
resp.End();
以上就是生成Excel的方法,当然这里是直接输出到客户端,所以没有生成多余的文件在服务器,如果非要生成文件在服务器,然后提供链接给客户端下载,其实就是将数据用文件流输出,保存为文件,然后将生成的文件路径返回给客户端,然后让客户端来请求这个文件路径,就能够下载了,示例如下:
StreamWriter sw = new StreamWriter(path, false, Encoding.GetEncoding("gb2312"));
sw.Write(str);//保存文件
sw.Close();
return Content("../DownLoad/file.xls");//不要忘了后缀.xls
生成word文件,方法也是一样的,只是有某些小地方需要修改:
resp.AppendHeader("Content-Disposition","attachment;filename="+HttpUtility.UrlEncode("file.doc", Encoding.UTF8));//后缀为doc
resp.ContentType = "application/msword";//文件内容为msword
其他都一致了。
当然生成这些文件的方法还有很多种,这里说的应该是最简单的一种。
.net生成Excel,并下载的更多相关文章
- phpexcel生成excel并下载
Loader::import('PHPExcel.Classes.PHPExcel'); // tp5中只需将phpexcel文件放入extend文件夹中,即可采用该方法引入,需要先 use thin ...
- 使用node.js生成excel报表下载(excel-export express篇)
引言:日常工作中已经有许多应用功能块使用了nodejs作为web服务器,而生成报表下载也是我们在传统应用. java中提供了2套类库实现(jxl 和POI),.NET 作为微软的亲儿子更加不用说,各种 ...
- java动态生成excel打包下载
@SuppressWarnings("unchecked") public String batchExport() throws DBException{ @SuppressWa ...
- Asp.net MVC 简单实现生成Excel并下载
由于项目上的需求,需要导出指定条件的Excel文件.经过一翻折腾终于实现了. 现在把代码贴出来分享 (直接把我们项目里面的一部份辅助类的代码分享一下) 我们项目使用的是Asp.Net MVC4.0模式 ...
- 后台生成excel前端下载
后台生成Excel时前端获取下载 Controller控制器: package com.example.test.controller; import com.example.test.common. ...
- ASP.NET网页生成EXCEL并下载(利用DataGrid或GridView等)
前几天要在后台查询数据库内容(用entity framework),将查询出来的信息(List或DataTable形式)转成EXCEL供用户下载.经过谷歌.百度搜索,终于搜出了一些代码.似乎可用了,结 ...
- php ajax生成excel并下载
目标:使用php,通过ajax请求的方式生成一个excel,然后下载. 思路:大致思路是发送一个ajax请求到后台,后台php处理后生成一个excel文件,然后把生成的文件放到一个临时目录,然后把文件 ...
- NPOI生成excel并下载
NPOI文件下载地址:http://npoi.codeplex.com/ 将文件直接引用至项目中即可,,,,, 虽然网上资料很多,但有可能并找不到自己想要的功能,今天闲的没事,所以就稍微整理了一个简单 ...
- java利用poi生成excel文件后下载本地
1.该功能需要poi的jar包,链接: http://pan.baidu.com/s/1migAtNq 密码: 38fx. 2.首先新建一个实体类,用以存放单个数据 public class Test ...
随机推荐
- BZOJ 2101: [Usaco2010 Dec]Treasure Chest 藏宝箱( dp )
dp( l , r ) = sum( l , r ) - min( dp( l + 1 , r ) , dp( l , r - 1 ) ) 被卡空间....我们可以发现 l > r 是无意义的 ...
- [转] Ant 编译 Android 项目为 Apk 实战, 常见问题解决
补充,自行安装Ant, 配置ant环境变量, 在android 项目 根目录下使用 android update project 可以自动生成 build.xml 和 local.peoperties ...
- ZOJ 2852 Deck of Cards DP
题意: 一一个21点游戏. 1. 有三个牌堆,分别为1X,2X,3X. 2. 纸牌A的值为1,纸牌2-9的值与牌面面相同,10(T).J.Q.K的值为10,而而joke(F)的值为 任意大大. 3. ...
- OKR 方法 学习笔记
最近公司兴起了对OKR这个词的讨论,并且听到时总会伴随提到KPI,提到绩效考核.那OKR到底是什么呢?与KPI的区别在哪里?与绩效考核有什么关系?它与我们现在推行的敏捷开发有啥关系呢?因此,就到网上查 ...
- 引用 RAM和ROM和Flash ROM的区别
用 饿狼 的 RAM和ROM和Flash ROM的区别 RAM(Random Access Memory)的全名为随机存取记忆体,它相当于PC机上的移动存储,用来存储和保存数据的.它在任何时候都可以读 ...
- 基于visual Studio2013解决算法导论之025双向循环链表
题目 双向循环链表 解决代码及点评 #include <stdio.h> #include <stdlib.h> #include <time.h> #in ...
- GUI动态创建button
#include "cocos2d.h" #include "cocos-ext.h" USING_NS_CC; USING_NS_CC_EXT; using ...
- 基于html5 localStorage , web SQL, websocket的简单聊天程序
new function() { var ws = null; var connected = false; var serverUrl; var connectionStatus; var send ...
- 分享非常有用的Java程序(关键代码)(七)---抓屏程序
原文:分享非常有用的Java程序(关键代码)(七)---抓屏程序 import java.awt.Dimension; import java.awt.Rectangle; import java.a ...
- WCF技术剖析之二十六:如何导出WCF服务的元数据(Metadata)[实现篇]
原文:WCF技术剖析之二十六:如何导出WCF服务的元数据(Metadata)[实现篇] 元数据的导出就是实现从ServiceEndpoint对象向MetadataSet对象转换的过程,在WCF元数据框 ...