ASP.NET 导出EXCEL文件处理多对应排列的
这次项目遇到了一个导出excel需要对应排列的问题。本来在做这个项目之前都基本没做过excel导出的菜鸡,这次强行做还是有些忐忑的,加上那个表的结构比较奇特。
废话不多说,先介绍表结构吧 是数据对应的排序周的表结构,一个列会有很多的周别信息,如下图展示:
由于才疏学浅,并没有遇到过这种列里面有16*2=32列的这种保存数据的方法,一列保存的是周别的信息,另一列保存的是数量信息。
当时就有想啊,我擦那直接导出来不就好了,直接就对应上了多简单!但是转念一想呢,万一要导出的不止16条呢,那后面的怎么加呢,和同事商量之后,有个同事的做法是列转行,就是把这个所有的列都转成行,这样就能按照属性(周别和数量)全部拿到数据了,但是呢,但是我比较烦写存储过程,想自己想想办法,加上我这边的筛选条件是有一个选择周别区间的,所以我自己想了一个办法,处理了这类的表。
这个界面能获取到的条件除了限定的这一条是属于谁的(查询条件的名称),还有就是起始周和周别和数量信息,这几个重要的信息了,值得一提的是,这里的起始周是这16列数据第一列的周别,所以是叫做起始周,这个字段可以好好的利用。
再重新解释下导出需求,导出要根据名称,导出的起始周和结束周往后推16这周的信息。这里为什么要推后16周呢,恩,需求书上说的,没有为什么。而且导出的数据要成那种菱形,就是那种那种额 不发图表达不了啊。。。还是发图吧。
就是这种前凸后翘的表格了,怎么说。。。
这样看来,这里的首行的列名,也就是他们的列台头就很重要, 因为下面的数据都要与之对应的上,所有抬头必须要长,尽量的长长长长长。。。。。。。。。。。。。。。。。。。(大概这么长)。
到了这一步,也是可以参考同事说的那种,就是那种,那种列转行的做法的,把所有的列都存在一列之中,然后DISTINCT出来做列头这样。但是我是真的懒得写存储过程。。。。
怎么做呢,前文提到我这里是有起始周的,于是我获取了结束周(这里的起始周和结束周都是可以与表中的起始周数据进行筛选的),然后往后推了16周,这样就能获取到所有查询到的数据的周别了。
然后让每一条数据的起始周与列的台头进行对比,如果周别是一样的,就放在对应的位置,上码上码!!!
try
{
string InquiiryFile = HttpContext.Current.Server.MapPath("~") + "\\Excel\\xxx.xlsx";
if (!File.Exists(InquiiryFile))
{
Page.RegisterStartupScript("", "<script>alert( '无法加载样式表,请与管理员联系!')</script>");
}
//导出
DataTable DT = init();
if (DT.Rows.Count > )
{
Aspose.Cells.License lic = new Aspose.Cells.License();
lic.SetLicense("Aspose.Cells.lic");
Aspose.Cells.Workbook excel = new Aspose.Cells.Workbook();
excel.Open(InquiiryFile);
Aspose.Cells.Worksheet sheet = excel.Worksheets[];
sheet = excel.Worksheets[];
string startWeek = txtStartWeek.Value;
string endWeek = txtEndWeek.Value;
if (endWeek != "")
{
int weeknumber = Convert.ToInt32(endWeek.Substring(, ));
int years = Convert.ToInt32(endWeek.Substring(, ));
if (weeknumber + > )
{
weeknumber = weeknumber + - ;
if (weeknumber < )
{
years = years + ;
endWeek = years.ToString() + "" + weeknumber.ToString();
}
else
{
years = years + ;
endWeek = years.ToString() + weeknumber.ToString();
}
}
else
{
weeknumber = weeknumber + 16;
endWeek = years.ToString() + weeknumber.ToString();
}
}
string where = "1=1";
if (startWeek != "")
{
where += " and [monthName]>='" + startWeek + "'";
}
if (endWeek != "")
{
where += " and [monthName]<='" + endWeek + "'";
}
DataTable dtweek = bll.byWeek(where);//获取到了所有的周别
int dtweeknumber = dtweek.Rows.Count;
for (int i = ; i < dtweek.Rows.Count; i++)
{
sheet.Cells[, ( + i)].PutValue("WK" + (dtweek.Rows[i]["monthName"].ToString()).Substring(, ));
string monthName = dtweek.Rows[i]["startTime"].ToString();
monthName = monthName.Substring(, ) + "年" + monthName.Substring(, ) + "月" + monthName.Substring(, ) + "日";
sheet.Cells[, ( + i)].PutValue(monthName);
}
for (int i = ; i < DT.Rows.Count; i++)
{
sheet.Cells[i + , ].PutValue(DT.Rows[i]["Name"].ToString()); //名称
sheet.Cells[i + , ].PutValue("WK" + (DT.Rows[i]["startWeek"].ToString()).Substring(, )); //起始周
if (DT.Rows[i]["startWeek"] != DBNull.Value)
{
for (int j = ; j < dtweeknumber; j++)
{
if (DT.Rows[i]["startWeek"].ToString() == dtweek.Rows[j]["monthName"].ToString())
{
sheet.Cells[i + , + j].PutValue(Convert.ToInt32(DT.Rows[i]["wkN"]));//起始周的位置
for (int w = ; w < ; w++)
{
sheet.Cells[i + , + j + w].PutValue(Convert.ToInt32(DT.Rows[i]["wkN" + w + ""]));//后续的数据插入位置
}
}
}
} } sheet.AutoFitColumns();
string excelName = "xxx" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + ".xlsx";
excel.Save(excelName, Aspose.Cells.FileFormatType.Excel2007Xlsx, Aspose.Cells.SaveType.OpenInExcel, HttpContext.Current.Response);
Response.End();
}
}
catch (Exception ex)
{
RegisterClientScriptBlock("", "<script>alert('" + ex.Message + "')</script>");
}
效果做出来了,可把我牛逼坏了,插会腰。
ASP.NET 导出EXCEL文件处理多对应排列的的更多相关文章
- asp.net 导出excel文件
之前做过winfrom程序的导出excel文件的功能,感觉非常简单.现在试着做asp.net中导出excel的功能,之前用的是Microsoft.Office.Interop.Excel这个对象来实现 ...
- ASP.NET导出Excel文件
第一种最常见,并且最简单的方式,直接把GridView导出,导出格式为文本表格形式. protected void btnSaveExcel_Click(object sender, EventArg ...
- ASP.NETCore -----导出Excel文件并下载
本事例分为nopi(安装DotNetCore.NPOI)下载和EPPlus(EPPlus.Core.dll)下载,其中npoi下载演示的是根据执行的模板进行数据下载 npoi帮助类NpoiExcelU ...
- ASP.NET 导出excel文件出现乱码的解决办法
string html =TABLE ;//<table>标签,可以是多张表string modified = Regex.Replace(html, "<table &g ...
- 关于asp.net C# 导出Excel文件 打开Excel文件格式与扩展名指定格式不一致的解决办法
-----转载:http://blog.csdn.net/sgear/article/details/7663502 关于asp.net C# 导出Excel文件 打开Excel文件格式与扩展名指定格 ...
- ASP.NET Core导入导出Excel文件
ASP.NET Core导入导出Excel文件 希望在ASP.NET Core中导入导出Excel文件,在网上搜了一遍,基本都是使用EPPlus插件,EPPlus挺好用,但商用需要授权,各位码友若有好 ...
- Asp.net导出Excel续章(自定义合并单元格,非Office组件)
结合上次写的导出Excel方法,这次上头要求我将列头进行一下合并 以前的效果: 改进后的效果: 在上篇文章中写到了Excel的导出方法,这次为了避免在生产环境中使用Office组件,服务器各种权限配置 ...
- asp.net导出excel示例代码
asp.net导出excel的简单方法. excel的操作,最常用的就是导出和导入. 本例使用NPOI实现. 代码:/// <summary> ); ; ...
- [转] Asp.Net 导出 Excel 数据的9种方案
湛刚 de BLOG 原文地址 Asp.Net 导出 Excel 数据的9种方案 简介 Excel 的强大之处在于它不仅仅只能打开Excel格式的文档,它还能打开CSV格式.Tab格式.website ...
随机推荐
- 根据源码用HttpServletRequest获取MultipartFile的问题
问题 由于某些原因,现在需要这样的一个文件上传接口,这个接口type(String)是必传参数,photoFile(MultipartFile)是非必传参数,即一般情况下需要接受两个参数,分别为pho ...
- java将类和函数封装成jar,然后在别的项目中使用这个jar包
本来想用idea安装的,不过用maven生成后发现jar有20,30M肯定不对,后来还是用eclipse生成了,方便很多 环境: eclipse luna,jdk1.8_112 1.生成jar包,首先 ...
- Eclipse导入项目常见问题----乱码问题03
有时打开导入的项目文件时,会出现如下图情况: 解决方法 如下图步骤所示: 此时,我们可以看到文件正常了 jdk版本问题(有个红色感叹号)01:http://blog.csdn.net/baidu_37 ...
- 一天搞定CSS:字体font--04
1.字体体系 2.字体各属性取值 说明: 每一个属性后面的分支是属性值,以及对属性值的说明. 比如font-weight- - - -有两个取值:bold,normal 3.演示代码 <!DOC ...
- java中的一些规则(菜鸟的课堂笔记)
ls 查看目录下文件 java规则 代码都定义在类中,用class定义 禁止一个源文件写两个类: 一个源文件中,只能有一个类文件是pubic: 一个源文件中如果有多个类,编译完之后会产生多个class ...
- python语言精粹《一》
第一章 静态语言:需要声明类型.变量不能改变类型! 动态语言:(也称脚本语言)主要的应用场景都是很短的应用程序(脚本),比如给静态语言编写的程序进行数据预处理.这样的程序通常也统称胶水代码. pyth ...
- ci框架学习告一段落,总结一下
从网上弄了一张框架学习思维导图,从图中就可以看出ci用了设计模式中的MVC架构,使得用起来很简单方便 用了大概两个星期开发了一个<文章管理系统>觉得开发过程中学到了很多,挺不错的,而且在学 ...
- [Leetcode] Binary search, DP--300. Longest Increasing Subsequence
Given an unsorted array of integers, find the length of longest increasing subsequence. For example, ...
- lucene全文搜索之二:创建索引器(创建IKAnalyzer分词器和索引目录管理)基于lucene5.5.3
前言: lucene全文搜索之一中讲解了lucene开发搜索服务的基本结构,本章将会讲解如何创建索引器.管理索引目录和中文分词器的使用. 包括标准分词器,IKAnalyzer分词器以及两种索引目录的创 ...
- javaCV开发详解之3:收流器实现,录制流媒体服务器的rtsp/rtmp视频文件(基于javaCV-FFMPEG)
javaCV系列文章: javacv开发详解之1:调用本机摄像头视频 javaCV开发详解之2:推流器实现,推本地摄像头视频到流媒体服务器以及摄像头录制视频功能实现(基于javaCV-FFMPEG.j ...