最近做了个项目,客户对导出excel功能情有独钟,几乎要求每一个列表数据都支持导出excel功能,为了避免代码重复,万能粉嫩的小码农开发了万能导出QAQ.

导出Excel无非就是取出数据,然后利用Aspose.Cells插件填充到Excel文件中,DataTable类型的数据是最适合填充Excel不过了.唯一的问题就是DataTable数据的列头一般是英文,突然就想出了利用SQL Server每一列的说明来替换掉英文列头的方法,我太TM机智了.

利用Aspose.Cells实现万能导出功能

/// <summary>
/// 导出
/// </summary>
/// <param name="dt">导出的数据表</param>
/// <param name="dic">字段名称,字段中文名称</param>
/// <param name="title">导出第一行标题</param>
/// <returns></returns>


public Workbook ExportData(DataTable table, Dictionary<string, string> dic, string title = "")
    {
      title = string.IsNullOrEmpty(title) "导出数据" : title;

      Workbook workbook = new Workbook();
      workbook.Worksheets.RemoveAt(0);//移除第一个sheet

      var tempStrArray = System.Activator.CreateInstance<T>().GetType().FullName.Split('.');//
      string tableName = tempStrArray[tempStrArray.Count() - 1];//这两句是反射生成要操作的表格名称的,
      var baseDic = GetColumnsByTable(tableName, "");

      foreach (DataColumn item in table.Columns)
      {
        string chsColumnName = "";
        if (baseDic.TryGetValue(item.ColumnName, out chsColumnName) && !string.IsNullOrEmpty(chsColumnName))
          item.ColumnName = chsColumnName;
        if (dic.TryGetValue(item.ColumnName, out chsColumnName) && !string.IsNullOrEmpty(chsColumnName))
          item.ColumnName = chsColumnName;
      }

      int Colnum = table.Columns.Count;//表格列数
      int Rownum = table.Rows.Count;//表格行数

      Worksheet sheet = workbook.Worksheets.Add(title);
      Cells cells = sheet.Cells;//单元格

      //为标题设置样式
      Style styleTitle = workbook.Styles[workbook.Styles.Add()];//新增样式
      styleTitle.HorizontalAlignment = TextAlignmentType.Center;//文字居中
      styleTitle.Font.Name = "宋体";//文字字体
      styleTitle.Font.Size = 18;//文字大小
      styleTitle.Font.IsBold = true;//粗体

      //样式2
      Style style2 = workbook.Styles[workbook.Styles.Add()];//新增样式
      style2.HorizontalAlignment = TextAlignmentType.Center;//文字居中
      style2.Font.Name = "宋体";//文字字体
      style2.Font.Size = 13;//文字大小
      style2.Font.IsBold = true;//粗体
      style2.IsTextWrapped = true;//单元格内容自动换行
      style2.Borders[BorderType.LeftBorder].LineStyle = CellBorderType.Thin;
      style2.Borders[BorderType.RightBorder].LineStyle = CellBorderType.Thin;
      style2.Borders[BorderType.TopBorder].LineStyle = CellBorderType.Thin;
      style2.Borders[BorderType.BottomBorder].LineStyle = CellBorderType.Thin;

      //样式3
      Style style3 = workbook.Styles[workbook.Styles.Add()];//新增样式
      style3.HorizontalAlignment = TextAlignmentType.Center;//文字居中
      style3.Font.Name = "宋体";//文字字体
      style3.Font.Size = 12;//文字大小
      style3.Borders[BorderType.LeftBorder].LineStyle = CellBorderType.Thin;
      style3.Borders[BorderType.RightBorder].LineStyle = CellBorderType.Thin;
      style3.Borders[BorderType.TopBorder].LineStyle = CellBorderType.Thin;
      style3.Borders[BorderType.BottomBorder].LineStyle = CellBorderType.Thin;

      //生成行1 标题行
      cells.Merge(0, 0, 1, Colnum);//合并单元格
      cells[0, 0].PutValue(title);//填写内容
      cells[0, 0].SetStyle(styleTitle);
      cells.SetRowHeight(0, 38);

      //生成行2 列名行
      for (int i = 0; i < Colnum; i++)
      {
        cells[1, i].PutValue(table.Columns[i].ColumnName);
        cells[1, i].SetStyle(style2);
        cells.SetRowHeight(1, 25);
        cells.SetColumnWidth(i, 30);
      }

      //生成数据行
      for (int i = 0; i < Rownum; i++)
      {
        for (int k = 0; k < Colnum; k++)
        {
          cells[2 + i, k].PutValue(table.Rows[i][k].ToString());
          if (k == Colnum - 1)
          {
            style3.HorizontalAlignment = TextAlignmentType.Left;//文字居中
          }
          else
          {
            style3.HorizontalAlignment = TextAlignmentType.Center;//文字居中
          }
          cells[2 + i, k].SetStyle(style3);
        }
        cells.SetRowHeight(2 + i, 24);
      }
      return workbook;
    }

/// <summary>
/// 获取某个表下面的所有列名和说明
/// </summary>
/// <param name="tbname">表名</param>
/// <param name="orderrule">排序规则</param>
/// <returns></returns>
public Dictionary<string, string> GetColumnsByTable(string tbname, string orderrule)
    {
      StringBuilder sqlsb = new StringBuilder();
      sqlsb.Append("SELECT distinct ColumnsName = c.name,Description = isnull(ex.value,'') ");
      sqlsb.Append("FROM sys.columns c LEFT OUTER JOIN sys.extended_properties ex ");
      sqlsb.Append("ON ex.major_id = c.object_id AND ex.minor_id = c.column_id AND ex.name = 'MS_Description' ");
      sqlsb.Append("left outer join systypes t on c.system_type_id=t.xtype ");
      sqlsb.Append("WHERE OBJECTPROPERTY(c.object_id, 'IsMsShipped')=0 AND ");
      sqlsb.Append("OBJECT_NAME(c.object_id) ='{0}' ");
      if (!string.IsNullOrEmpty(orderrule))
      {
        sqlsb.Append("order by ColumnsName {1}");
      }
      else
      {
        sqlsb.Append("order by ColumnsName ASC");
      }

      string exsql = string.Format(sqlsb.ToString(), tbname, orderrule);

      DataTable dt = DB.FromSql(exsql).ToTable() as DataTable;//用了MySoft框架QAQ

      Dictionary<string, string> dic = new Dictionary<string, string>();
      if (dt != null && dt.Rows.Count > 0)
      {
        for (int i = 0; i < dt.Rows.Count; i++)
        {
          dic.Add(dt.Rows[i][0].ToString(), dt.Rows[i][1].ToString());
        }
      }
      return dic;
    }

两个搞定了,能实现绝大部分的导出业务。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

标签:
Aspose.Cells,导出

免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
狼山资源网 Copyright www.pvsay.com

评论“利用Aspose.Cells实现万能导出功能”

暂无“利用Aspose.Cells实现万能导出功能”评论...

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。