最近做了個項目,客戶對導出excel功能情有獨鐘,幾乎要求每一個列表數據都支持導出excel功能,為了避免代碼重復,萬能粉嫩的小碼農開發了萬能導出QAQ.
導出Excel無非就是取出數據,然后利用Aspose.Cells插件填充到Excel文件中,DataTable類型的數據是最適合填充Excel不過了.唯一的問題就是DataTable數據的列頭一般是英文,突然就想出了利用SQL Server每一列的說明來替換掉英文列頭的方法,我太TM機智了.
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