导出数据到Excel表格
开发工具与关键技术:Visual Studio 和 ASP.NET.MVC,
作者:陈鸿鹏
撰写时间:2019年5月25日
1
2
3
下面是我们来学习的导出数据到Excel表格的总结
首先在视图层写导出数据的点击事件
function 自定义点击事件名()
{
//然后这里获取当前表格数据的筛选条件
var 自定义下拉框名 = $("#下拉框id “).val();
//后面根据你的条件数依次写
……
var 自定义文本框名 = $(”#文本框id ").val();
//然后这里写判断它是否为空
if (自定义下拉框名 == "" || 自定义下拉框名 == undefined) {
ID = 0;
}
//这里也是根据上面的依次在后面写
……
if (自定义文本框名 == undefined) {
自定义文本框名 = "";
}
//这里再接着输出一下,询问用户是否导出,如果是就输出后面的function回调函数,layer是调用的layui插件的弹出层
layer.confirm("询问语句", { icon: 3, title: "提示" }, function (layerIndex) {
layer.close(layerIndex);
//根据上面的筛选条件在后面依次写参数
window.open("控制器写的自定义导出方法名?根据上面的筛选条件依次写的参数);
});
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
//然后再到控制器写方法
//后面的括号写写前面条件筛选的参数的条数
public ActionResult 自定义导出方法名(int id参数, ……string 文本框参数)
{
//然后这里紧接着写查询数据
List<自定义类的类名> 自定义列表名A = (from 自定义的表名1 in Model对象.连接的表1
join 自定义的表名 in Model对象.连接的表2 on 连接的表1.(连接的条件,对应ID值) equals 连接的表2.(连接的条件,对应ID值)
连接的表3 on 连接的表2.(连接的条件,对应ID值) equals 连接的表3.(连接的条件,对应ID值) (主外键相连)
orderby tbEmployee.EmployeeID descending(排序)
select new 自定义类的类名 {
类的属性1 = 自定义的表名.字段1,
类的属性2 = 自定义的表名.字段2,
类的属性3 = 自定义的表名.字段3,
……
}).Single();查询单条数据,当没有数据或者有多条数据时会触发异常
.ToList();查询多条数据并转为List
.Count();查询有多少条数据
//然后这里写条件筛选 Lambda表达式 运算符=>,左边是参数(如果有),右边是表达式或者语句
if (参数> 0)
{
自定义列表名A = 自定义列表名A.Where(m => m.对应id ==对应id).ToList();
}
if (参数2> 0)
{
自定义列表名A = 自定义列表名A.Where(m => m.对应id ==对应id).ToList();
}
if (!string.IsNullOrEmpty(文本框))
{
自定义列表名A = 自定义列表名A.Where(m => m.文本框里面写的数据.Contains(文本框id) || m.文本框里写的数据.Contains(文本框id)).ToList();
}
//然后这里接着写创建Excel工作簿
HSSFWorkbook 自定义工作簿名 = new HSSFWorkbook();
//然后这里再接着创建工作表,这里的NPOI是插件,NPOI就是在你没有安装office的时候可以读取Excel和word文档。创建表用ISheet,Sheet就是创建工作表的名字
NPOI.SS.UserModel.ISheet 自定义工作表名 = 自定义工作簿名.CreateSheet(“工作表的名字”);
//然后再接着创建表头行,创建行用IRow,0就表示第一行
NPOI.SS.UserModel.IRow 自定义表头行名A = 自定义工作表名.CreateRow(0);
//再接着设置表头,CreateCell是索引,SetCellValue设置表头行的值,需要多少就创建多少
自定义表头行名A.CreateCell(0).SetCellValue(“表头名字”);
自定义表头行名A.CreateCell(1).SetCellValue(“表头名字”);
自定义表头行名A.CreateCell(2).SetCellValue(“表头名字”);
……
//然后再接着for循环把数据一条一条的写到Excel表格
for (int i = 0; i < 上面的自定义列表名A.Count(); i++)
{
//创建行,这里的自定义行名不要和上面的重复
NPOI.SS.UserModel.IRow 自定义行名B = 自定义工作表名.CreateRow(i + 1);
//然后添加数据,这里的数据根据表头的数据名依次写
自定义行名B.CreateCell(0).SetCellValue(自定义列表名A [i].对应数据名);
自定义行名B.CreateCell(1).SetCellValue(自定义列表名A [i].对应数据名);
自定义行名B.CreateCell(2).SetCellValue(自定义列表名A [i].对应数据名);
自定义行名B.CreateCell(3).SetCellValue(自定义列表名A [i].对应数据名);
……
}
//然后再接着为Excel文件命名,DateTime再文件名后加上时间,yyyy-MM-dd-HH-mm-ss-ffff表示年月日时分秒毫秒,如下图为导出后的文件名,考生信息就是文件名,后面的数字是导出的时间.xls是后缀
string 自定义文件名 = “文件名” + DateTime.Now.ToString(“yyyy-MM-dd-HH-mm-ss-ffff”) + “文件后缀”;
//这里是创建一个内存流来保存二进制数组 MemoryStream 自定义内存流名 = new MemoryStream();
//这里将Excel文件写入内存流
自定义工作簿名.Write(自定义内存流名);
//输出之前调用Seek(偏移量,游标位置) 移动文件读取指针到指定的位置
//Seek(0,Seek.begin) 第一个参数表示相对位置,第二个参数表示参照位置
ExcelStream.Seek(0, SeekOrigin.Begin);
//然后返回到页面MIME文件类型(Multipurpose Internet Mail Extensions)多用途互联网邮件扩展类型
return File(自定义内存流名, “application/vnd.ms-excel”, 自定义文件名);
}
最后到这里导出数据到Excel表格就完成了。
---------------------
导出数据到Excel表格的更多相关文章
- Java操作Jxl实现导出数据生成Excel表格数据文件
实现:前台用的框架是Easyui+Bootstrap结合使用,需要引入相应的Js.Css文件.页面:Jsp.拦截请求:Servlet.逻辑处理:ClassBean.数据库:SQLserver. 注意: ...
- Python导出数据到Excel表格-NotImplementedError: formatting_info=True not yet implemented
在使用Python写入数据到Excel表格中时出现报错信息记录:“NotImplementedError: formatting_info=True not yet implemented” 报错分析 ...
- PHP批量导出数据为excel表格
之前用插件phoexcel写过批量导入数据,现在用到了批量导出,就记录一下,这次批量导出没用插件,是写出一个表格,直接输出 //$teacherList 是从数据库查出来的二维数组 $execlnam ...
- php动态导出数据成Excel表格
一.封装 Excel 导出类 include/components/ExecExcel.php <?php /*** * @Excel 导入导出类. */ class ExecExcel { / ...
- spring boot 使用POI导出数据到Excel表格
在spring boot 的项目经常碰到将数据导出到Excel表格的需求,而POI技术则对于java操作Excel表格提供了API,POI中对于多种类型的文档都提供了操作的接口,但是其对于Excel表 ...
- Excel VBA ——如何导出数据到excel表格
sub OutPut() Dim FileTitle, MyPath, MyFullName As String Application.ScreenUpdating = false '关闭表格公式的 ...
- Java导出数据生成Excel表格
事先准备: 工具类: package com.wazn.learn.util.export; import java.sql.Connection; import java.sql.DriverMan ...
- PHP:引用PhpExcel导出数据到excel表格
我使用的是tp3.2框架(下载地址:http://www.thinkphp.cn/topic/38123.html) 1.首先要下载PhpExcel类库,放在如下图目录下 2.调用方法 public ...
- pl/sql developer导出数据到excel的方法
http://yedward.net/?id=92 问题说明:使用pl/sql developer导出数据到excel表格中是非常有必要的,一般的可能直接在导出的时候选择csv格式即可,因为该格式可以 ...
随机推荐
- Lua中..和#运算符的用法
Lua中..和#运算符的用法 样例 试试以下的样例就明确了在Lua编程语言提供的其它运算符: a = "Hello " b = "World" print(&q ...
- 字符串匹配之KMP算法(续)---还原next数组
相信通过今天的文章,你会对KMP的认识更加深入一层,不止停留在知道怎样计算的层面上了,废话不多说,開始. 通过前面的第一篇文章,知道了怎么求next数组,相信非常多喜欢刨根问底的人就会问,我依照你的做 ...
- Android学习笔记-tween动画之java实现
Android动画分为Tween动画和Frame动画,近期学习了,体tween动画,现在讲学习的心得以及相关知识介绍如下. Tween又称为补间动画,可以把对象进行缩小.放大.旋转和渐变等操作. ...
- [计算机故障]toshiba笔记本计算机无法正常启动,每次均需要按ESC
同事一台toshiba的笔记本计算机,无法正常启动,每次均需要按ESC才可以正常后续动作. 之后系统可以正常工作. 排查过程: 1.尝试恢复bios到默认配置:不行,而且不小心搞了个蓝屏,还好记得是“ ...
- 用py文件调用操作系统的命名,粘包问题
帅爆太阳的男人 1,执行代码 在py代码中去调用操作系统的命令 新的模块:subprocess, import subprocess r = subprocess().Popen( "dir ...
- 实时人工智能:微软发布Project Brainwave预览版 现场可编程门阵列(Field Programmable Gate Array,简称FPGA) 硬件设计可以迅速演进
https://mp.weixin.qq.com/s/bAPiPURZd-YsbV5PbzwpQQ 编者按:随着各大公司对于数据计算的要求越来越高,实时AI成为了研究者们关注的重点.在美国西雅图举行的 ...
- MFC中SliderCtrl控件的使用
在MFC中滑动条(CSliderCtrl)是个经常使用的控件,使用方法例如以下: 主要要方法有: 1.设置.取得滑动范围: void SetRange( int nMin, int nMax, BOO ...
- [Codeforces 140C] New Year Snowmen
[题目链接] https://codeforces.com/problemset/problem/140/C [算法] 显然 , 我们每次应优先考虑数量多的雪球 将雪球个数加入堆中 , 每次取出数量前 ...
- POJ1743 Musical Theme 最长重复子串 利用后缀数组
POJ1743 题目意思是求不重叠的最长相同变化的子串,输出该长度 比如1 2 3 4 5 6 7 8 9 10,最长长度为5,因为子串1 2 3 4 5 和 6 7 8 9 10变化都一样的 思路: ...
- poj 1286 Necklace of Beads【polya定理+burnside引理】
和poj 2409差不多,就是k变成3了,详见 还有不一样的地方是记得特判n==0的情况不然会RE #include<iostream> #include<cstdio> us ...