这两天项目上用Aspose导出Excel来着。开始感觉挺简单的,但是实际操作起来还是挺复杂的,调试占的时间很长。主要是动态生成列、合并单元格、调样式占了很长时间,还是总结一下吧。

  基础操作:

  //EXCEL模板路径

  var filePath = HttpContext.Current.Server.MapPath("~/" + ConfigurationManager.CurrentPackage.Settings["FilePath"]);

  //打开模板sheet

var book = new Workbook();
    book.Open(filePath);
    var sheet = book.Worksheets[0];

//根据需要给单元格赋值,Excel行列的索引都是从0开始的。

  sheet.Cells[i,j].PutValue("**");

  动态生成列:

  根据模板情况访问数据库得到DataTable,尽量得到和Excel布局相近的数据记录。循环写单元格,合并需要合并的单元格,设置样式。

  合并单元格: 

    //合并标题行,因为列是动态添加的,所以标题居中显示,得重新根据列宽合并单元格
    Range rangeTitle = sheet.Cells.CreateRange(firstRow, firstColumn, totalRows, totalColumns);//创建需要合并的Range范围再进行合并
      //rangeTitle.UnMerge(); //如果这个范围中本来n个单元格已经是合并过的,需要取消合并再Merge,否则会报错。
    rangeTitle.Merge(); //合并range

  样式:

    int styleIndex = book.Styles.Add(); //在当前样式集合中创建一个样式,返回创建样式索引,设置样式必须在原有样式集合中再添加一个样式,否则会覆盖原样式
    Style style = book.Styles[styleIndex]; 
    style.RotationAngle = 255; //这个角度值研究了半天,可以把汉字从左到右显示,改成从上到下,垂直显示。可以试一下。

    Range range = sheet.Cells.CreateRange(startRowIndex - catalogNameRowSpan + 1, 0, catalogNameRowSpan, 1); //得到要使用样式的范围
    range.SetStyle(style); //设置样式

    //根据原有样式,拷贝样式

    Range rangeRows = sheet.Cells.CreateRange(firstRow, firstColumn, totalRows, totalColumns);//要赋样式的范围
    rangeRows.CopyStyle(sheet.Cells.CreateRange(4, 1, 1, 6)); //把(4, 1, 1, 6)的样式赋到rangeRows范围上。

    //应用样式(给单元格加边框,每个边的框宽度根据多次设置样式的最大粗细为准)

    Style GridStyle = book.Styles[book.Styles.Add()];
    GridStyle.Borders[BorderType.TopBorder].LineStyle = CellBorderType.Medium; //设置上边框粗细
    GridStyle.Borders[BorderType.TopBorder].Color = Color.Black; //设置边框颜色
    GridStyle.Borders[BorderType.BottomBorder].LineStyle = CellBorderType.Medium;//设置下边框粗细
    GridStyle.Borders[BorderType.BottomBorder].Color = Color.Black;
    GridStyle.Borders[BorderType.LeftBorder].LineStyle = CellBorderType.Thin;//设置左边框粗细
    GridStyle.Borders[BorderType.LeftBorder].Color = Color.Black;
    GridStyle.Borders[BorderType.RightBorder].LineStyle = CellBorderType.Medium;//设置右边框粗细
    GridStyle.Borders[BorderType.RightBorder].Color = Color.Black;
    GridStyle.HorizontalAlignment = TextAlignmentType.Center;//文本居中对齐
    GridStyle.Font.Size = 9; //设置字体9号
    Range range1 = sheet.Cells.CreateRange(4, 0, 1, 6 + totalColumns); //样式应用范围
    StyleFlag borderStyle = new StyleFlag(); //标示集合,启用哪个样式
    borderStyle.Borders = true; //启用Borders样式
    borderStyle.HorizontalAlignment = true; //启用水平对齐样式
    borderStyle.Font = false;//不使用配置的字体样式
    range1.ApplyStyle(GridStyle, borderStyle); //应用多种样式。borders设置:由于LeftBorder设置CellBorderType.Thin,范围是单行多列多单元格的,所以每个单元格左边框被设置两次,按最粗的样式显示,第一个单元格左框是Thin,其他列的单元格左框是Medium。

使用Aspose.Cell.dll导出Excel总结的更多相关文章

  1. Aspose.Cells 导入导出EXCEL(转)

    Aspose.Cells 导入导出EXCEL      修改样式        Workbook workbook = new Workbook(); //工作簿          Worksheet ...

  2. [转]Excel.dll 导出Excel控制

    Excel.dll 导出Excel控制 2010-06-12 11:26 2932人阅读 评论(2) 收藏 举报 excelmicrosoftstring产品服务器google 最近做了个导出Exce ...

  3. C# WinForm使用Aspose.Cells.dll 导出导入Excel/Doc 完整实例教程

    1.添加引用: Aspose.Cells.dll(我们就叫工具包吧,可以从网上下载.关于它的操作我在“Aspose.Cells操作说明 中文版 下载 Aspose C# 导出Excel 实例”一文中的 ...

  4. 使用aspose.cell动态导出多表头 EXCEL

    效果图: 前台调用: using System; using System.Collections.Generic; using System.Linq; using System.Web; usin ...

  5. NPOI、MyXls、Aspose.Cells 导入导出Excel(转)

    Excel导入及导出问题产生: 从接触.net到现在一直在维护一个DataTable导s出到Excel的类,时不时还会维护一个导入类.以下是时不时就会出现的问题: 导出问题: 如果是asp.net,你 ...

  6. 根据路径获得文件名以及Aspose.Cells.dll操作excel 以及使用iTextSharp.text.pdf.PdfReader.dll对PDF的操作

    string result = Regex.Match(str,@"[^\\]+$").Value;//正则表达式 this.listBox1.Items.Add(Path.Get ...

  7. Aspose.cell.dll的使用,导excel表

    using System; using System.Web; using EF; using Newtonsoft.Json; using System.Collections.Generic; u ...

  8. Aspose.cell中的Excel模板导出数据

    //Excel模板导数据(Eexcel中根据DataTable中的个数,给多个Sheet中的模板赋值) public void DataSetToManyExcel(string fileName, ...

  9. Aspose.cell C# 操作excel(通过批注信息给单元格赋值、批注信息获取公式得出结果并转PNG)

    if (fileName == "") return ""; var CurrentRow = 0; Workbook work = new Workbook( ...

随机推荐

  1. Oracle语句优化之一

    public List<TdDepartment> createZtreeDep(String compId) { List<TdDepartment> dd = new Ar ...

  2. METEOR 及ANGULARJS

    最近学习:METEOR 及ANGULARJS,收藏相关资源: 1.METEOR 中文书:http://zh.discovermeteor.com/ 2.METEOR 及ANGULARJS 联合开发:h ...

  3. linux日常小坑

    一.权限 1.文件权限 改动文件权限和所有权的命令有如下两个: chmod -更改权限 chown -更改所有权 不过,只有用户是当前所有者或者根用户,才能实际更改文件的权限或所有权,这一点大家要注意 ...

  4. Qt 对话框显示控制按钮

    在对话框窗体构造函数加入 SystemDialog::SystemDialog(QWidget *parent) : QDialog(parent), ui(new Ui::SystemDialog) ...

  5. 内存管理_JAVA内存管理

    Java虚拟机规范中试图定义一种Java内存模型(Java Memory Model,JMM)来屏蔽各个硬件平台和操作系统的内存访问差异,以实现让Java程序在各种平台下都能达到一致的内存访问效果.那 ...

  6. Effective C++ -----条款10: 令operator=返回一个reference to *this

    比如: Widget& operator=(const Widget& rhs) { ... return* this; } 令赋值(assignment)操作符返回一个referen ...

  7. code vs1436 孪生素数 2(数论+素数的判定)

    1436 孪生素数 2  时间限制: 2 s  空间限制: 1000 KB  题目等级 : 白银 Silver 题解  查看运行结果     题目描述 Description 如m=100,n=6 则 ...

  8. Android 启动白屏或者黑屏闪现解决

    1.设置Style //1.设置背景图Theme <style name="Theme.AppStartLoad" parent="android:Theme&qu ...

  9. 【python】lxml中多个xml采用相同节点时出现的问题

    今天突然发现了一个lxml的坑. 假设我们有一个节点 <id>123</id> 有两个父节点都要用上述节点,则必须把上面的节点写两遍!用同一个会出错! 出错例子: #!/usr ...

  10. IOS-Uikit框架介绍

    •UIKit可识别三种类型的输入事件: –触摸事件 –运动(加速计)事件 –远程控制事件 IKit框架将触击信息封装为一个UIEvent对象,并派发给恰当的视图(有关UIKit如何将事件递送给您的视图 ...