一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - ASP.NET教程 - 利用Aspose.Cells實現萬能導出功能

利用Aspose.Cells實現萬能導出功能

2020-06-05 17:35canyanol ASP.NET教程

這篇文章主要為大家詳細介紹了利用Aspose.Cells實現萬能導出功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下

最近做了個項目,客戶對導出excel功能情有獨鐘,幾乎要求每一個列表數據都支持導出excel功能,為了避免代碼重復,萬能粉嫩的小碼農開發了萬能導出QAQ.

導出Excel無非就是取出數據,然后利用Aspose.Cells插件填充到Excel文件中,DataTable類型的數據是最適合填充Excel不過了.唯一的問題就是DataTable數據的列頭一般是英文,突然就想出了利用SQL Server每一列的說明來替換掉英文列頭的方法,我太TM機智了.

利用Aspose.Cells實現萬能導出功能

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
/// <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;
    }

 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
/// <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;
    }

兩個搞定了,能實現絕大部分的導出業務。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:https://blog.csdn.net/canyanol/article/details/51093809

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产在视频线在精品 | 亚洲免费视频一区 | 亚洲卡一卡2卡三卡4卡无卡三 | 亚洲精品无码不卡在线观看 | 日本五级床片全都免费播放 | 美女做又爽又黄又猛 | 亚洲国产天堂久久精品网 | 国产一级在线观看视频 | 色碰视频 | 忘忧草研究院一二三 | 久久伊人在| 韩国三级日本三级香港三级黄 | 华人在线视频 | 无码专区aaaaaa免费视频 | 国产成人欧美视频在线 | 日本aaaa级 | 热久久最新网址 | 亚洲AV无码专区国产精品麻豆 | 三上悠亚国产精品一区 | 干露露视频 性感写真 | 出差被灌醉绝伦的上司日本 | pron在线观看 | 午夜爱爱爱爱爽爽爽视频网站 | 欧美一区a| 国产原创精品 | 青青草国产免费国产是公开 | 天天舔天天操天天干 | 午夜福利院电影 | 草女人逼| 国产精品成人一区二区 | 暖暖在线精品日本中文 | 日韩亚洲欧美理论片 | 色婷婷激婷婷深爱五月老司机 | 欧美日韩一区二区三区免费 | 欧美精品日韩 | 国产一级一级一级成人毛片 | 国产在线看片护士免费视频 | 久久精品国产亚洲AV蜜臀 | 成人伊人青草久久综合网破解版 | 四虎最新永久免费网址 | 91精品国产91热久久久久福利 |