导出数据到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表格就完成了。
---------------------

原文地址:https://www.cnblogs.com/hyhy904/p/10992433.html

时间: 2024-10-15 14:39:57

导出数据到Excel表格的相关文章

spring boot 使用POI导出数据到Excel表格

摘自:https://www.cnblogs.com/hopeofthevillage/p/12099807.html spring boot 使用POI导出数据到Excel表格 2019-12-26 00:17  全me村的希望  阅读(42)  评论(0)  编辑收藏 在spring boot 的项目经常碰到将数据导出到Excel表格的需求,而POI技术则对于java操作Excel表格提供了API,POI中对于多种类型的文档都提供了操作的接口,但是其对于Excel表格的操作无疑是最强大的.

C#中导出数据到Excel表格中

之前PM交给我一个自动化测试的Case,让我抓取页面上的数据到Excel表格中,刚好又接了一个之前人家做的系统, 刚好看到可以用NPOI导数据,就动手试试,成功导出. 由于鄙人比较菜,也比较懒, 怕自己忘记了,今天就总结一下,以防下次用可以参考. 1.要使用NPOI,首先需要在Project中Install NPOI的 Package. 右键点击Project------>Manage NuGet Packages---->Search NPOI----->点击搜索到的NPOI然后点击等

Python脚本:实现数据库导出数据到excel表格,支持mysql,postergrsql,MongoDB

import xlwt #返回需要导出的对象的集合,根据业务字型实现 def getObjList(): return [] # 制定 表格行 和数据库字段的对应 obj_feild = { 0: 'name', # 表格第一行是名字 1: 'age', # 表格第二行是年龄 2: 'sno', # 表格第三行是学号 3: 'sex', # 表格第四行是性别 } # 制定数据库字段和中文的对应 field_chinese = { 'name':'名字', # 数据库字段 name对应excel表

Java导出数据生成Excel表格

事先准备: 工具类: package com.wazn.learn.util.export; import java.sql.Connection; import java.sql.DriverManager; public class DbUtil { private String dbUrl="jdbc:mysql://localhost:3306/basepro"; private String dbUserName="user"; private Strin

pl/sql developer导出数据到excel的方法

http://yedward.net/?id=92 问题说明:使用pl/sql developer导出数据到excel表格中是非常有必要的,一般的可能直接在导出的时候选择csv格式即可,因为该格式可以直接用excel打开.但是,在导出的时候出现了这样的问题,导出成csv格式的时候出现了数据乱码,而导出为xml或者html的时候却不会出现问题. 图1:pl/sql developer导出为csv出现乱码 问题解析:出现上面的问题,可能是字符集的设置问题.我找到了一些其他的数据导出方法,下面一一列出

在ASP.NET Web Forms中使用页面导出伪xls Excel表格

将数据导出为Excel表格是比较常见的需求,也有很多组件支持导出真正的Excel表格.由于Excel能打开HTML文件,并支持其中的table元素以及p之类的文本元素的显示,所以把.html扩展名改为.xls是比较常用的一种方式.当然这只是一种骗人的伎俩,所以我称之为伪xls表格.不过对于要求不高的需求,这种方法还是比较简单快捷的. 在Web Forms项目中,除了用代码拼凑HTML元素标记外,还可以直接用窗体页面渲染HTML表格.Web Forms就是用来渲染动态HTML的,直接利用它,支持代

PHP导出数据到Excel

PHP导出数据到Excel 在Web开发中经常需要将一些数据导入到Excel表格中,比如需要导出符合条件的用户数据,导出项包括姓名.性别.***号.联系方式等等.那么问题来了,在导出的数据中如果出现比较长的数值类型的项时,默认按科学计数法表示,比如***号这显然不是我们需要的,那么我们怎么做才能让数据按我们要求的格式显示呢? 查到一些相关资料,摘抄如下: 首先,我们了解一下excel从web页面上导出的原理.当我们把这些数据发送到客户端时,我们想让客户端程序(浏览器)以excel的格式读取它,所

Delphi 导出数据至Excel的7种方法【转】

转自:http://blog.csdn.net/zang141588761/article/details/52275948 一; delphi 快速导出excel uses ComObj,clipbrd; function ToExcel(sfilename:string; ADOQuery:TADOQuery):boolean; const xlNormal=-4143; var y : integer; tsList : TStringList; s,filename :string; a

delphi导出数据至Excel的七种方法及比较

一;delphi 快速导出excel uses ComObj,clipbrd; function ToExcel(sfilename:string; ADOQuery:TADOQuery):boolean;const      xlNormal=-4143;var    y     :  integer;    tsList :  TStringList;    s,filename  :string;    aSheet  :Variant;    excel :OleVariant;