Asp.Net中应用Aspose.Cells输出报表到Excel 及样式设置
解决思路:
1、找个可用的Aspose.Cells(有钱还是买个正版吧,谁开发个东西也不容易);
2、在.Net方案中引用此Cells;
3、写个函数ToExcel(传递一个DataTable),可以另写个SetCellStyle的函数专门给各列设置样式。
4、在按钮的Click事件中调用此ToExcel()即可。
注:想更详细了解的到Aspose网站去,那里有很多在线文档,够你看的了。也可以下载个Demo程序研究。
部分代码贴在这里,代码还有需要改进的地方,暂时这么用着,给自己以后方便查找,再者给真正接触此控件的同志们抛个砖头:
ExportToExcel()的:
- /// <summary>
- /// 利用Aspose.Cells对DataTable数据生成Excel文件
- /// </summary>
- /// <returns>是否成功</returns>
- /// <param name="response">包含存储路径,直接用Response即可</param>
- /// <param name="dt">数据体</param>
- /// <param name="FileName">文件名</param>
- /// <param name="SheetName">sheet名</param>
- /// <param name="Title">表头</param>
- /// <param name="ColTitle">列标题,字符串数组</param>
- /// <param name="ColName">列名,字符串数组</param>
- /// <param name="ColWidth">列宽,整数数组</param>
- /// <param name="ColStyle">列样式,整数数组,1=居中文本、2=特殊字体Georgia、3=居左文本、4=整数(x)、5=2位小数(x,xxx.xx)、6=日期(yyyy-M-d不带时间)、7=百分数(0.123=12.3%)</param>
- /// <param name="ColTitleRow">列标题的开始行号,有title的设为1即可</param>
- /// <param name="err">返回的错误信息</param>
- public bool ExportToExcel(System.Web.HttpResponse response,DataTable dt, string FileName, string SheetName, string Title,
- ArrayList ColTitle, ArrayList ColName, ArrayList ColWidth, ArrayList ColStyle, int ColTitleRow, ref string err)
- {
- //先检查各数组是否个数一致
- if (ColTitle.Count != ColName.Count || ColTitle.Count != ColWidth.Count || ColTitle.Count != ColStyle.Count)
- {
- err = "数据组个数不一致";
- return false;
- }
- try
- {
- Workbook workbook = new Workbook();
- //打开模版文件
- // string path = System.Web.HttpContext.Current.Server.MapPath("~");
- // path = path.Substring(0, path.LastIndexOf("//"));
- // path += @"/designer/Workbooks/NumberFormatting.xls";
- // workbook.Open(path);
- //打开sheet
- workbook.Worksheets.Clear();
- Worksheet worksheet = workbook.Worksheets.Add(SheetName);
- worksheet = workbook.Worksheets[0];
- Cells cells = worksheet.Cells;
- //cells.ClearContents(0,0,60,30);
- //加入样式
- ArrayList styles = new ArrayList();
- styles = SetCellStyle(workbook, ColStyle);
- //加入Title即表头,类似“xxx汇总表”,其占居所有列数
- Range w;//范围
- if(ColTitleRow>0)
- {
- //Put数据到某个cell中
- cells[0,0].PutValue(Title);
- //设置行高
- cells.SetRowHeight(0, 35);
- //合并单元格
- cells.Merge(0,0,1,(byte)ColName.Count);
- //CreateRange函数参数说明:cells.CreateRange(firstrow, firstcol, rownumber, colnumber)
- w=cells.CreateRange(0,0,1,(byte)ColName.Count);
- //设置该合并单元的Style
- //w.Style = (Aspose.Cells.Style)styles[ColStyle.Count];
- w.Style = workbook.Styles["SheetTitle"];
- }
- //给各列的标题行PutValue,类似“序号,类型,名称,价格,数量,合计”
- int currow = ColTitleRow;
- byte curcol = 0;
- foreach(string s in ColTitle)
- {
- cells[currow,curcol++].PutValue(s);
- cells.SetRowHeight(ColTitleRow, 25);
- }
- //设置列标题行的Style
- w=cells.CreateRange(currow,0,1,ColName.Count);
- w.Style = (Aspose.Cells.Style)styles[ColStyle.Count+1];
- //上面这行也可以写成
- //w.Style = workbook.Styles["ColTitle"];//ColTitle在函数SetCellStyle中设置了
- currow++;
- //将数据体按顺序插入各cell
- for(int i=0; i<dt.Rows.Count; i++)
- {
- curcol = 0;
- for(int j=0; j<ColName.Count; j++)
- {
- object val = dt.Rows[i][ColName[j].ToString()].ToString().Trim();
- switch (int.Parse(ColStyle[j].ToString()))
- {
- case 4://整数
- if (val.ToString().Length>0)
- val = Int32.Parse(val.ToString());
- else
- val = "";
- break;
- case 5://2位小数
- if (val.ToString().Length>0)
- val = Decimal.Parse(val.ToString());
- else
- val = "";
- break;
- case 6://日期
- if (val.ToString().Length>0)
- val = DateTime.Parse(val.ToString());
- else
- val = "";
- break;
- case 7://百分数,1=100%
- if (val.ToString().Length>0)
- val = Decimal.Parse(val.ToString());
- else
- val = "";
- break;
- default:
- break;
- }//end switch
- cells[currow,curcol++].PutValue(val);
- }//end for j
- currow ++;
- } //end for i
- curcol = 0;
- //设置数据体Style
- for(int i=0; i<dt.Columns.Count; i++)
- {
- w = cells.CreateRange(ColTitleRow+1, i, dt.Rows.Count, 1);
- w.Style = (Aspose.Cells.Style)styles[i];
- }
- //w=cells.CreateRange(ColTitleRow+1,col,currow,ColName.Count);
- //w.Style=excel.Styles["Data"];
- //设置各列宽度
- foreach(int s in ColWidth)
- cells.SetColumnWidth(curcol++, s);
- /*
- //********可参考的格式设置*******************************************************
- //Set number format with built-in index
- for (int i = 0; i < 37; i ++)
- {
- cells[i, 1].PutValue(1234.5);
- //int Number = cells[i, 0].IntValue;
- //Set the display number format
- cells[i, 1].Style.Number = i;
- }
- //Set number format with custom format string
- for (int i = 1; i < 4; i ++)
- {
- cells[i, 3].PutValue(1234.5);
- //Set the display custom number format
- cells[i, 3].Style.Custom = cells[i, 2].StringValue;
- }
- //********可参考的格式设置*******************************************************
- */
- //workbook.Save(FileName, FileFormatType.Default, SaveType.OpenInExcel, System.Web.HttpContext.Current.Response);
- workbook.Save(FileName, FileFormatType.Default, SaveType.OpenInExcel, response);
- return true;
- }
- catch (Exception ex)
- {
- err = ex.Message;
- return false;
- }
- }//end ExportToExcel()
- #endregion
样式设置SetStyle()的:
- #region SetCellStyle()设置格式,如果需要增加新的格式,请在case后面增加,不要修改前面的
- public ArrayList SetCellStyle(Workbook workbook, ArrayList styleindex)
- {
- //通用设置样式的
- ArrayList CellStyle = new ArrayList(styleindex.Count + 2);
- Aspose.Cells.Style style = null;
- for (int i=0; i<styleindex.Count; i++)
- {
- int index = workbook.Styles.Add();
- style = workbook.Styles[index];
- style.Name = "Custom_Style" + ((int)(i + 1)).ToString();
- style.ForegroundColor = Color.White;
- style.HorizontalAlignment = TextAlignmentType.Center;
- style.VerticalAlignment = TextAlignmentType.Center;
- style.Font.Name = "宋体";
- style.Font.Size = 10;
- style.Borders[BorderType.LeftBorder].LineStyle = CellBorderType.Thin;
- style.Borders[BorderType.RightBorder].LineStyle = CellBorderType.Thin;
- style.Borders[BorderType.TopBorder].LineStyle = CellBorderType.Thin;
- style.Borders[BorderType.BottomBorder].LineStyle = CellBorderType.Thin;
- switch((int)styleindex[i])
- {
- case 1://居中文本
- style.HorizontalAlignment = TextAlignmentType.Center;
- style.VerticalAlignment = TextAlignmentType.Center;
- break;
- case 2://特殊字体Georgia
- style.Font.Name = "Georgia";
- break;
- case 3://文本列
- style.HorizontalAlignment = TextAlignmentType.Left;
- break;
- case 4://整数列 1 Decimal 0
- style.HorizontalAlignment = TextAlignmentType.Center;
- style.Number = 1;
- break;
- case 5://2位小数 39={Currency #,##0.00;-#,##0.00} 40={#,##0.00;[Red]-#,##0.00}
- style.HorizontalAlignment = TextAlignmentType.Right;
- style.Number = 40;
- break;
- case 6://日期列 14 Date yyyy-m-d
- style.HorizontalAlignment = TextAlignmentType.Center;
- style.Number = 14;//这个格式不是太好,还需要调整
- break;
- case 7://百分比% 10 Percentage 0.00%
- style.HorizontalAlignment = TextAlignmentType.Center;
- style.Number = 10;
- break;
- default:
- break;
- }//end switch
- CellStyle.Add(style);
- }
- //特别增加一个用于表头的style.Name = "SheetTitle";
- int sindex = workbook.Styles.Add();
- style = workbook.Styles[sindex];
- style.Name = "SheetTitle";
- style.Font.Size = 14;
- style.Font.IsBold = true;
- style.Font.Name = "楷体_GB2312";
- style.HorizontalAlignment = TextAlignmentType.Center;
- style.VerticalAlignment = TextAlignmentType.Center;
- style.Borders[BorderType.LeftBorder].LineStyle = CellBorderType.Thin;
- style.Borders[BorderType.RightBorder].LineStyle = CellBorderType.Thin;
- style.Borders[BorderType.TopBorder].LineStyle = CellBorderType.Thin;
- style.Borders[BorderType.BottomBorder].LineStyle = CellBorderType.Thin;
- CellStyle.Add(style);
- //特别增加一个用于列标题的style.Name = "ColTitle";
- sindex = workbook.Styles.Add();
- style = workbook.Styles[sindex];
- style.Name = "ColTitle";
- style.Font.Size = 12;
- style.Font.IsBold = true;
- style.Font.Name = "宋体";
- style.HorizontalAlignment = TextAlignmentType.Center;
- style.VerticalAlignment = TextAlignmentType.Center;
- style.Borders[BorderType.LeftBorder].LineStyle = CellBorderType.Thin;
- style.Borders[BorderType.RightBorder].LineStyle = CellBorderType.Thin;
- style.Borders[BorderType.TopBorder].LineStyle = CellBorderType.Thin;
- style.Borders[BorderType.BottomBorder].LineStyle = CellBorderType.Thin;
- CellStyle.Add(style);
- //返回样式数组
- return CellStyle;
- }//end SetCellStyle
- #endregion
Asp.Net中应用Aspose.Cells输出报表到Excel 及样式设置的更多相关文章
- aspose.cells根据模板导出excel
又隔十多天没写博客了,最近都在忙项目的事情,公司人事变动也比较大,手头上就又多了一个项目.最近做用aspose.cells根据模板导出excel报价单的功能,顺便把相关的核心记下来,先上模板和导出的效 ...
- C# -- 使用Aspose.Cells创建和读取Excel文件
使用Aspose.Cells创建和读取Excel文件 1. 创建Excel Aspose.Cells.License li = new Aspose.Cells.License(); li.SetLi ...
- 在ASP.NET MVC中利用Aspose.cells 将查询出的数据导出为excel,并在浏览器中下载。
正题前的唠叨 本人是才出来工作不久的小白菜一颗,技术很一般,总是会有遇到一些很简单的问题却不知道怎么做,这些问题可能是之前解决过的.发现这个问题,想着提升一下自己的技术水平,将一些学的新的'好'东西记 ...
- C# WinForm使用Aspose.Cells.dll 导出导入Excel/Doc 完整实例教程
1.添加引用: Aspose.Cells.dll(我们就叫工具包吧,可以从网上下载.关于它的操作我在“Aspose.Cells操作说明 中文版 下载 Aspose C# 导出Excel 实例”一文中的 ...
- 用Aspose.Cells控件读取Excel
Aspose是一个很强大的控件,可以用来操作word,excel,ppt等文件,用这个控件来导入.导出数据非常方便.其中Aspose.Cells就是用来操作Excel的,功能有很多.我所用的是最基本的 ...
- java利用Aspose.cells.jar将本地excel文档转化成pdf(完美破解版 无水印 无中文乱码)
下载aspose-cells-8.5.2.jar包 http://pan.baidu.com/s/1kUBzsQ7 JAVA代码 package webViewer; import java.io.* ...
- 使用Aspose.Cells利用模板导出Excel(C#)
前言 随着互联网的流行,web项目逐渐占据主流.我相信大部分人开发项目的过程中都写过上传以及导出Excel和Word的功能,本文仅讨论导出Excel.C#中有很多第三方组件支持导出Excel,比如:N ...
- 基于 Aspose.Cells与XML导入excel 数据----操作类封装
前言 导入excel数据, 在每个项目中基本上都会遇到,第三方插件或者基于微软office,用的最多的就是npoi,aspose.cells和c#基于office这三种方式,其中各有各的优缺点,在这也 ...
- 使用Aspose.Cells 根据模板生成excel里面的 line chart
目的: 1.根据模板里面的excel数据信息,动态创建line chart 2.linechart 的样式改为灰色 3.以流的形式写到客户端,不管客户端是否装excel,都可以导出到到客户端 4.使用 ...
随机推荐
- jackson注解使用心得
maven依赖: <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId ...
- 好程序与差程序Good Programming, Bad Programming
好程序与差程序 Good Programming, Bad Programming 发布时间: 2012-11-20 16:32:21| 阅读数:2,735 views 优秀的程序可以使复杂的东西看起 ...
- Windows下使用WSRM限制MongoDB内存
有个项目用到了MongoDB,我们是在WINDOWS 2008 64位环境下部署的,为啥不部署到linux下面呢,我们没那么多服务器,只能将就一下了. 大家都知道Mongodb吃内存太厉害了,如果不重 ...
- 《React Native入门与实战》读书笔记(1)
ReactNative介绍 它的底层引擎是JavaScript Core,调用的是原生组件而非HTML5组件(HTML+CSS+JavaScript构建的组件).运行时,可以做到与Native App ...
- Android界面组件的四种启动方式
Android界面组件启动有四种方式 standard,singleTop,singleTask,singleInstance. standard:每次调用都会都会产生新的组件. singletop: ...
- Node.js 学习笔记
时间:2016-07-07 提前安装好linux CentOs环境,以及相关工具(git,wget,vim……) 1.安装: 目前打算在CentOs上进行操作,网上有教程是旧的地址,这个是搬家后的新地 ...
- Spring操作指南-AOP基本示例(基于注解)
- docker 学习
vim /usr/lib/systemd/system/docker.service ExecStart=/usr/bin/docker daemon --bip=172.18.42.1/16 --r ...
- Nexus安装及部署(含如何在Tomcat中部署)
1. Nexus价值 1)方便-节约带宽-快 2)便于统一管理 3)持续集成需要 2.Nexus下载 http://www.sonatype.org/nexus/go 3.Nexus启动 解压后进入\ ...
- Leetcode: Minimum Unique Word Abbreviation
A string such as "word" contains the following abbreviations: ["word", "1or ...