正题前的唠叨

本人是才出来工作不久的小白菜一颗,技术很一般,总是会有遇到一些很简单的问题却不知道怎么做,这些问题可能是之前解决过的。发现这个问题,想着提升一下自己的技术水平,将一些学的新的‘好’东西记录下来,一是加深印象;二是以后可以作为参考;三是希望博友们可以提出不足和可以优化的地方,一起讨论。

本方法是通过ajax直接下载,当然也可以直接button下载,本方法类已经实现导入导出,请执行扩展。谢谢

效果图:点击导出按钮

前端 AJAX

    //导出ececl
function btn_excel(ExeclID) {
var myConfirmCode = ' <div id="downloaddiv" style="display: none">\
<a id = "downloadRul" href = "" > \
<p>\
</p>\
</a >\
</div >'; $("body").append(myConfirmCode); $.ajax({
type: "GET",
url: "../../tools/downloadExecl.ashx?action=GetExcel",
data: { "ExeclID": ExeclID, "TempName":"", "Outname":"" },
dataType: "json",
success: function (data) {
if (data.status == ) {
$("#downloadRul").attr("href", data.msg);
$('#downloadRul>p').trigger("click"); $("#downloaddiv").remove();
} else {
$("#downloaddiv").remove();
alert("请登入系统");
}
}
});
// $("#downloaddiv").remove(); }

主要是导出excel并在浏览器下载下来。 但是会有不同的细微的需求差别。

进入正题

简单的需求描述

将查询出来已经转化好了的list<T> xxx 的数据的某些列,导入到excel之中,并在浏览器中下载下来。

public void GetExcel(HttpContext context)
{
string ExeclID = MXRequest.GetString("ExeclID");//导出模板ID,管理sql
BLL.InfoExecl infoExeclbll = new BLL.InfoExecl();
infoExecl= infoExeclbll.GetModel(MyCommFun.Obj2Int( ExeclID));
if (Outname != "") {
infoExecl.titlename = Outname;
}
if (TempName != "")
{
infoExecl.title = TempName;
} DataTable dt = new DataTable(); // DataTable 数据源 string download = Manage.ExeclOUtAjax(infoExecl.Sql, infoExecl.title, infoExecl.titlename); context.Response.Write("{\"status\":1, \"msg\": \""+ download + "\"}"); }
        /// <summary>
/// 导出Exec方法
/// </summary>
/// <param name="sql"></param>
/// <param name="temppathName"></param>
/// <param name="Outname"></param>
public string ExeclOUtAjax(string sql, string temppathName, string Outname)
{
string timeflie= DateTime.Now.ToString("yyyyMMddHHmmss");
DataSet ds = DBUtility.DbHelperSQL.Query(sql);
//导出数据
string temppath = Server.MapPath("\\UpFile");
string filepath = temppath + "\\ExportExcel\\" + temppathName + ".xls";//临时文件,也作为模板文件
string downUrl = "\\ExcelOut\\" + timeflie+ Outname+ ".xls";//导出文件路径
string downUrlAjax = "/UpFile/ExcelOut/" + timeflie + Outname + ".xls";//下载文件路径
string outfilepath = temppath + downUrl;//导出文件路径
AsposeExcel asposeexcel = new AsposeExcel(outfilepath, filepath);
asposeexcel.DatatableToExcel(ds.Tables[0]);
//return DownFile("\\UpFile" + downUrl, DateTime.Now.ToString("yyyyMMdd") + "零售品牌汇总导出.xls");
//获取项目绝对路径地址
string url = HttpContext.Current.Request.Url.AbsoluteUri.ToString().Split('/')[0] + "//" + HttpContext.Current.Request.Url.Authority.ToString();
var virtualPath = System.Web.Hosting.HostingEnvironment.ApplicationVirtualPath;
string fileName = "";
if (virtualPath != "/")
{
//有子应用程序
fileName = virtualPath + "/UpFile/";
}
else
{
fileName = "/Document/TemporaryDocuments/" + tempExcelName;
} //清除历史文件,避免历史文件越来越多,可进行删除
DirectoryInfo dyInfo = new DirectoryInfo(HttpContext.Current.Server.MapPath("/UpFile/ExcelOut/"));
//获取文件夹下所有的文件
foreach (FileInfo feInfo in dyInfo.GetFiles())
{
//判断文件日期是否小于两天前,是则删除
if (feInfo.CreationTime < DateTime.Today.AddDays(-2))
feInfo.Delete(); } return url+ downUrlAjax; }

  

  

后端 公共操作类

AsposeExcel.cs 类

 using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;
using Aspose.Cells;
using System.IO;
using System.Web; namespace Flysem.Common
{
public class AsposeExcel
{
private string outFileName = "";
private string fullFilename = "";
private Workbook book = null;
private Worksheet sheet = null;
/// <summary>
///
/// </summary>
/// <param name="outfilename">导出文件路径</param>
/// <param name="tempfilename">模板文件路径</param>
public AsposeExcel(string outfilename, string tempfilename) //导出构造数
{
Aspose.Cells.License license = new Aspose.Cells.License();
license.SetLicense("Aspose.Cells.lic"); outFileName = outfilename;
book = new Workbook();
//book.Open(tempfilename);//这里我们暂时不用模板
// 打开 Excel 模板
book = File.Exists(tempfilename) ? new Workbook(tempfilename) : new Workbook();
sheet = book.Worksheets[];
}
/// <summary>
/// 保存文件
/// </summary> /// <param name="name"></param>
public void SaveReprotFile( string name)
{
// book.Save(System.Web.HttpContext.Current.Response, "学生信息.xls", ContentDisposition.Attachment, new XlsSaveOptions(SaveFormat.Xlsx)); book.Save(System.Web.HttpContext.Current.Response, HttpUtility.UrlEncode(name, System.Text.Encoding.UTF8) + ".xls", ContentDisposition.Attachment, new XlsSaveOptions(SaveFormat.Excel97To2003));
//try
//{
// // filePath = Server.MapPath(filePath);
// if (File.Exists(name))
// {
// FileInfo info = new FileInfo(name);
// long fileSize = info.Length;
// HttpContext.Current.Response.Clear();
// HttpContext.Current.Response.ContentType = "application/octet-stream";
// HttpContext.Current.Response.AddHeader("Content-Disposition", "attachement;filename=" + (info.FullName.));
// //指定文件大小
// HttpContext.Current.Response.AddHeader("Content-Length", fileSize.ToString());
// HttpContext.Current.Response.WriteFile(name, 0, fileSize);
// HttpContext.Current.Response.Flush();
// }
//}
//catch
//{ } //#region 输出到Excel
//using (MemoryStream ms = new MemoryStream())
//{
// // 生成的文件名称
// // string ReportFileName = string.Format("Excel_{0}.xls", DateTime.Now.ToString("yyyy-MM-dd") + name); // book.Save(ms, new OoxmlSaveOptions(SaveFormat.Xlsx));//默认支持xls版,需要修改指定版本
// System.Web.HttpContext.Current.Response.AddHeader("Content-Disposition", string.Format("attachment; filename={0}.xls", name));
// System.Web.HttpContext.Current.Response.ContentType = "application/vnd.ms-excel";
// System.Web.HttpContext.Current.Response.BinaryWrite(ms.ToArray());
// book = null;
// System.Web.HttpContext.Current.Response.End();
//}
//#endregion
} /// <summary>
///
/// </summary>
/// <param name="outfilename">导出文件路径</param>
/// <param name="tempfilename">导入文件路径</param>
/// <param name="tempfilename">模板文件路径</param>
public AsposeExcel(string outfilename, string fullfilename, string tempfilename) //导出构造数
{
Aspose.Cells.License license = new Aspose.Cells.License();
license.SetLicense("Aspose.Cells.lic"); outFileName = outfilename;
fullFilename = fullfilename;
book = new Workbook();
// book.Open(tempfilename);这里我们暂时不用模板
sheet = book.Worksheets[];
}
/// <summary>
/// 导入文件路径
/// </summary>
/// <param name="fullfilename"></param>
public AsposeExcel(string fullfilename) //导入构造数
{
Aspose.Cells.License license = new Aspose.Cells.License();
license.SetLicense("Aspose.Cells.lic"); fullFilename = fullfilename;
// book = new Workbook();
// book.Open(tempfilename);
// sheet = book.Worksheets[0];
}
private void AddTitle(string title, int columnCount)
{
sheet.Cells.Merge(, , , columnCount);
sheet.Cells.Merge(, , , columnCount);
Cell cell1 = sheet.Cells[, ];
cell1.PutValue(title);
Style style = new Style(); style.HorizontalAlignment = TextAlignmentType.Center;
style.Font.Name = "黑体";
style.Font.Size = ;
style.Font.IsBold = true;
Cell cell2 = sheet.Cells[, ];
cell1.PutValue("查询时间:" + DateTime.Now.ToLocalTime());
cell2.SetStyle(style);
}
private void AddHeader(DataTable dt)
{
Cell cell = null;
Style style = new Style();
for (int col = ; col < dt.Columns.Count; col++)
{
cell = sheet.Cells[, col];
cell.PutValue(dt.Columns[col].ColumnName);
style.Font.IsBold = true;
cell.SetStyle(style);
}
}
private void AddBody(DataTable dt)
{
Style style = new Style();
for (int r = ; r < dt.Rows.Count; r++)
{
for (int c = ; c < dt.Columns.Count; c++)
{
sheet.Cells[r+, c].PutValue(dt.Rows[r][c].ToString());
style.Font.Name = "宋体";
style.Font.Size = ;
sheet.Cells[r + , c].SetStyle(style);
//r+数值,这个数值再加1表示从第几行开始
//sheet.Cells[r + 1, c].PutValue(dt.Rows[r][c].ToString());
}
}
} //导出------------下一篇会用到这个方法
public Boolean DatatableToExcel(DataTable dt)
{
Boolean yn = false;
try
{
//sheet.Name = sheetName;
//AddTitle(title, dt.Columns.Count);
//AddHeader(dt);
AddBody(dt);
sheet.AutoFitColumns();
//sheet.AutoFitRows();
book.Save(outFileName);
yn = true;
return yn;
}
catch (Exception e)
{
return yn;
// throw e;
}
}
public DataTable ExcelToDatatalbe()//导入
{
Workbook book = new Workbook();
book.Open(fullFilename);
Worksheet sheet = book.Worksheets[];
Cells cells = sheet.Cells;
//获取excel中的数据保存到一个datatable中
DataTable dt_Import = cells.ExportDataTableAsString(, , cells.MaxDataRow + , cells.MaxDataColumn + , false);
// dt_Import.
return dt_Import;
}
}
}

利用Aspose.cells 将查询出的数据导出为excel,并在浏览器中下载。的更多相关文章

  1. 在ASP.NET MVC中利用Aspose.cells 将查询出的数据导出为excel,并在浏览器中下载。

    正题前的唠叨 本人是才出来工作不久的小白菜一颗,技术很一般,总是会有遇到一些很简单的问题却不知道怎么做,这些问题可能是之前解决过的.发现这个问题,想着提升一下自己的技术水平,将一些学的新的'好'东西记 ...

  2. 将查询到的数据导出到Excel终结版

    吐槽 最近新项目需要用到导出数据到Excel,试了试之前写的一篇博文,但是感觉那个不太好,主要原因是没能实现样式控制,今天我们就来介绍一种新的导出Excel方法,而且这种方法很轻量级,它利用xml生成 ...

  3. 怎么利用Aspose.Cells 获取excel 数据表中sheet的名称

    说明:开发环境 vs2012 asp.net mvc4 c# 利用Aspose.Cells 获取Excel数据表的sheet的名称,并把获取的名称赋值给easyUI 的combobox 1.运行效果 ...

  4. 匿名类型 使用泛型T linq返回dynamic类型的匿名实体 如何把匿名类型.GetType()返回的对象传进泛型里面 EF实体查询出的数据List<T>转DataTable出现【DataSet 不支持 System.Nullable<>】的问题

    [100分]紧急求助:LinQ下使用IQueryable<T>如何将返回类型<T>使用匿名类型 问题描述如下:我有一个方法如下:public IQueryable Dissen ...

  5. sql语句中查询出的数据添加一列,并且添加默认值

    查询出数据,并且要添加一列表中都不存在的数据,且这一列的值都是相等的 select app_id,app_secret from wx_ticket group by app_id; 查询出的数据是 ...

  6. 使用POI把查询到的数据表数据导出到Excel中,一个表一个sheet.最详细!!!

    一.需求 我们会遇到开发任务: 经理:小王,你来做一下把数据库里的数据导出到Excel中,一个表是一个sheet,不要一个表一个Excel. 小王:好的,经理.(内心一脸懵逼) 二.前期准备 首先我们 ...

  7. Java利用Apache POI将数据库数据导出为excel

    将数据库中的数据导出为excel文件,供其他人查看 public class POITest { public static void main(String[] args) { POITest te ...

  8. asp.net将数据导出到excel

    本次应用datatable导出,若用gridview(假设gridview设为了分页显示)会出现只导出当前页的情况. protected void btnPrn_Click(object sender ...

  9. 使用apache的poi来实现数据导出到excel的功能——方式二

    此次,介绍利用poi与layui table结合导出excel.这次不需要从数据库中查询出来的数据进行每一行的拼接那么麻烦,我们这次将标题定义一个id值,对应从数据库中查找出来的字段名即可. 1.po ...

随机推荐

  1. 系统重装后,Mysql数据库重装加载原来数据库

    相信不只我一个人因为重新装了系统后,导致mysql数据库无法使用的问题.尽管可以重新安装一个mysql服务端程序在自己的电脑上,但是要如何才能够将之前的数据库也一并重新恢复呢? 今天,我找到了解决之道 ...

  2. Java练习 SDUT-2499_数字

    数字 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 定义f(x) = {比x小,不可以被x整除并且不和x互质的数的个数 ...

  3. 让开发部署提速 8 倍,我参与贡献这款 IDE 插件的全过程

    如何像参与开源那样,去参与一款 IDE 插件的设计? 作为一款 IDE 插件的使用者,我是否能决定下一个版本的功能? 自从产品经理银时小伙和他的开发小哥们在去年12月发布 Cloud Toolkit( ...

  4. MySQL列出当前月的每一天

    因为工作的原因,要用MySQL列出当前月份每一天的日期,自己查了下网上资料都是列出最近一个月的日期的解决方案,自己根据查到的的方案,修改成了下面两个方案,在此记录下: 方案一: SELECT date ...

  5. day1_python之字符串的常用操作

    python字符串操作常用操作,如字符串的替换.删除.截取.复制.连接.比较.查找.分割等,需要的朋友可以参考下. 1.去除空格 str.strip():删除字符串两边的指定字符,括号的写入指定字符, ...

  6. Ubuntu 开机自动挂载磁盘

    Ubuntu 磁盘挂载 1.使用命令查看分区 sudo fdisk -l 1 可以根据上图提供的磁盘信息确定想挂载的磁盘,以及确定挂载的位置. 我此次的目的是将/dev/sda2 磁盘挂载到/mnt/ ...

  7. logback 打印mybatis sql mybatis 日志打印sql语句和返回结果

    logback 打印sql语句: 在logback日志文件中开启debug模式 <logger name="com.ibatis" level="DEBUG&quo ...

  8. 利用sort对数字排序

    sort,可排序字符串,按照ASCII码排序. 但也可以穿一个比较函数,实现比较数组内容,排序数组的功能. var arr = [40, 32, 45, 89, 93, 0, 46, 74]; var ...

  9. 限制允许某些IP访问服务器

    买了台阿里云服务器,部署了一些东西在上面,但是最近老是发现有异常登录,而且不仅仅是登录就完事了,还把服务器上一些重要的项目数据文件都给删除了,由于本人不是专业的运维人员,单位也没有运维人员,百度了一下 ...

  10. java StringBuffer 与 StringBuilder

    String是不可变类,一旦String对象被创建,包含在对象中的字符序列是不可变的,直到对象被销毁: StringBuffer 与 StringBuilder对象则是可变的! 举例说明这两个的好处: ...