概述

在做.Net web开发的过程中经常需要将查出的数据导成Excel表返给用户,方便用户对数据的处理和汇总。这里我将导出Excel表格的代码做一个总结,这也是我项目中经常用到的,代码简单易懂,使用方便,分享给大家。

1、查询数据,数据需要是datatable

后端代码实例,先给Excel表头转化为中文描述

 public OperationResult CreateExportExcel(Model queryModel)
{
string errorMsg;
DataSet ds = GetService.RunPRC_ConfirmCompSKD(queryModel, out errorMsg);
if (!string.IsNullOrEmpty(errorMsg))
{
return new OperationResult("", errorMsg);
}
if (ds.Tables.Count != )
{
return new OperationResult("", "查询为空");
}
DataTable dt = ds.Tables[];
dt.Columns.Remove(dt.Columns["DeptID"]);
dt.Columns.Remove(dt.Columns["SearchKey"]);//删除不需要的列
dt.Columns["FYear"].ColumnName = "年份";
dt.Columns["FMonth"].ColumnName = "月份";
dt.Columns["FranchiseeNo"].ColumnName = "编号";
dt.Columns["FranchiseeName"].ColumnName = "名称";
dt.Columns["DeptName"].ColumnName = "维护部门";
dt.Columns["FContractNo"].ColumnName = "合同编号";
dt.Columns["FDate1"].ColumnName = "起租日期";
dt.Columns["FDate2"].ColumnName = "止租日期";
dt.Columns["FNumber"].ColumnName = "收款单编号";
dt.Columns["FAmount"].ColumnName = "收款金额";
dt.Columns["FDate"].ColumnName = "收款日期";
dt.Columns["SkdNo"].ColumnName = "已核销收款单编号";
dt.Columns["SkdAmount"].ColumnName = "已核销收款金额";
dt.Columns["SkdDate"].ColumnName = "已核销收款日期";
return Export(dt, "收款单-");
}
     /// <summary>
/// 生成导出临时文件
/// </summary>
/// <param name="dt"></param>
/// <param name="preName"></param>
/// <returns></returns>
private OperationResult Export(DataTable dt, string preName)
{ dt.TableName = preName + DateTime.Now.ToString("yyyyMMddHHmmss"); string baseDictory = AppDomain.CurrentDomain.BaseDirectory; string dirctory = string.Format("{0}Doc", baseDictory); if (!Directory.Exists(dirctory))
{
Directory.CreateDirectory(dirctory);
} string path = string.Format("{1}Doc/{0}.xls", dt.TableName, baseDictory); string serverPath = path; if (File.Exists(serverPath))
{
File.Delete(serverPath);
} ExcelUtil.SaveAsExcel(serverPath, preName, dt); bool flag = File.Exists(serverPath); if (!flag)
{
return new OperationResult("", "生成失败");
} var result = new OperationResult("", "success")
{
returnURL = string.Format("/Doc/{0}", Path.GetFileName(serverPath))
}; return result;
}
public class OperationResult
{
public OperationResult()
{
} public OperationResult(string errCode, string errMsg)
{
ErrorCode = errCode;
ErrorMsg = errMsg;
} /// <summary>
/// 返回状态
/// </summary>
public bool Flag { get; set; } /// <summary>
/// 返回码
/// </summary>
public string ErrorCode { get; set; } /// <summary>
/// 返回的URL
/// </summary>
public string returnURL { get; set; } /// <summary>
/// 返回消息
/// </summary>
public string ErrorMsg { get; set; }
public object ObjectData { get; set; }
public object rows { get; set; } public int total { get; set; }
/// <summary>
/// 页脚
/// </summary>
public object footer { get; set; } }

前端代码实例:

 function  outExcel() {
var queryUrl = "/Statistics/D_IComeData/CreateD_MonthIncomeExportExcel";
var queryModel = form2Json("searchform");
$.ajax({
type: "POST",
url: queryUrl,
data: queryModel,
dataType: "JSON",
success: function (result) {
var row = result.rows;
if (Util.isValidResult(row)) {
if (row.hasOwnProperty("returnURL") && row.returnURL != null) {
OpenFrameUrl(row.returnURL);
}
}
}
});
} function OpenFrameUrl(url) {
var form = document.createElement("form");
form.id = "outExcelResult";
form.action = url;
form.method = "get";
document.body.appendChild(form);
form.submit();
document.body.removeChild(form); };

.Net生成导出Excel的更多相关文章

  1. java使用poi生成导出Excel(新)

    导出样式: java代码: import java.io.FileOutputStream; import java.io.IOException; import java.io.OutputStre ...

  2. 如何用poi生成导出excel

    import org.apache.poi.ss.usermodel.CellStyle; import org.apache.poi.ss.usermodel.Sheet; import java. ...

  3. java后台动态生成导出excel

    p ublic void export(List<WechatUser> wechatUserList, HttpServletResponse response) throws IOEx ...

  4. asp.net core webapi 生成导出excel

    /// <summary> /// 下载订单 /// </summary> /// <param name="model"></param ...

  5. 022医疗项目-模块二:药品目录的导入导出-对XSSF导出excel类进行封装

    资源全部来源于传智播客. 好的架构师写的程序,就算给刚入门的新手看,新手一看就知道怎么去用.所以我们要对XSSF导出excel类进行封装.这是架构师的工作,但我们也要知道. 我们写一个封装类: 这个类 ...

  6. 分享我基于NPOI+ExcelReport实现的导入与导出EXCEL类库:ExcelUtility (续3篇-导出时动态生成多Sheet EXCEL)

    ExcelUtility 类库经过我(梦在旅途)近期不断的优化与新增功能,现已基本趋向稳定,功能上也基本可以满足绝大部份的EXCEL导出需求,该类库已在我们公司大型ERP系统全面使用,效果不错,今天应 ...

  7. 根据模板导出Excel报表并生成多个Sheet页

    因为最近用报表导出比较多,所有就提成了一个工具类,本工具类使用的场景为  根据提供的模板来导出Excel报表 并且可根据提供的模板Sheet页进行复制 从而实现多个Sheet页的需求, 使用本工具类时 ...

  8. 懒人小工具:自动生成Model,Insert,Select,Delete以及导出Excel的方法

    在开发的过程中,我们为了节约时间,往往会将大量重复机械的代码封装,考虑代码的复用性,这样我们可以节约很多时间来做别的事情.最近跳槽到一节webform开发的公司,主要是开发自己公司用的ERP.开始因为 ...

  9. 懒人小工具:T4自动生成Model,Insert,Select,Delete以及导出Excel的方法

    之前写了篇文章,懒人小工具:[自动生成Model,Insert,Select,Delete以及导出Excel的方法](http://www.jianshu.com/p/d5b11589174a),但是 ...

随机推荐

  1. java的方法传参,最容易混淆的问题!!!

    参数传递 参数传递,可以理解当我们要调用一个方法时,我们会把指定的数值,传递给方法中的参数,这样方法中的参数就拥有了这个指定的值,可以使用该值,在方法中运算了.这种传递方式,我们称为参数传递. 在这里 ...

  2. docker redis

    https://www.cnblogs.com/cgpei/p/7151612.html 重启docker >systmctl restart docker >mkdir -p ~/red ...

  3. 迷你MVVM框架 avalonjs 沉思录 第2节 DOM操作的三大问题

    jQuery之所以击败Prototype.js,是因为它自一开始就了解这三大问题,并提出完善的解决方案. 第一个问题,DOM什么时候可用.JS不像C那样有一个main函数,里面的逻辑不分主次.但JS是 ...

  4. ubuntu ibus&language 启动失败

    [ubuntu ibus&language 启动失败] 版本:ubuntu 10.04 现像:language support & ibus 无法启动,导致无法使用中文输入法 原因:l ...

  5. rabbitmq的简单介绍一

    该博客的主要讲解了以下几种rabbitmq的用法1.实现简单的生产者发送消息给消费者2.实现序列持久化3.实现消息持久化4.实现消息公平分发5.实现广播6.实现组播7.实现细分组播 先来看下rabbi ...

  6. Cplus Overolad new and delete Operator

    思考:在C++类中,通过设计类的构造和析构函数,就已经把复杂的内存管理起来了. 及时是简单的结构体,也是有构造和析构函数的,而下面这种情况,可以在非结构中使用. /** Operator Overlo ...

  7. Create Empty Project In Vs But Not Debug?

    问题描述 在使用VS创建一个空的项目管理,然后,添加项目.可是,这个时候,项目虽然可以运行,但是不能Debug进行调试. 解决方法 按照下面三张图像的设置即可.

  8. Python操作mysql之模块pymysql

    pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb几乎相同.但目前pymysql支持python3.x而后者不支持3.x版本. 本文环境 python3.6.1  Mysql ...

  9. RNA -seq

    RNA -seq RNA-seq目的.用处::可以帮助我们了解,各种比较条件下,所有基因的表达情况的差异. 比如:正常组织和肿瘤组织的之间的差异:检测药物治疗前后,基因表达的差异:检测发育过程中,不同 ...

  10. cakephp执行原生sql语句

    $sql = 'select sum(amount) as amount from option_capital where status = 2 and amount > 0 and user ...