利用Aspose.Cells實(shí)現(xiàn)萬(wàn)能導(dǎo)出功能
最近做了個(gè)項(xiàng)目,客戶對(duì)導(dǎo)出excel功能情有獨(dú)鐘,幾乎要求每一個(gè)列表數(shù)據(jù)都支持導(dǎo)出excel功能,為了避免代碼重復(fù),萬(wàn)能粉嫩的小碼農(nóng)開(kāi)發(fā)了萬(wàn)能導(dǎo)出QAQ.
導(dǎo)出Excel無(wú)非就是取出數(shù)據(jù),然后利用Aspose.Cells插件填充到Excel文件中,DataTable類型的數(shù)據(jù)是最適合填充Excel不過(guò)了.唯一的問(wèn)題就是DataTable數(shù)據(jù)的列頭一般是英文,突然就想出了利用SQL Server每一列的說(shuō)明來(lái)替換掉英文列頭的方法,我太TM機(jī)智了.
/// <summary> /// 導(dǎo)出 /// </summary> /// <param name="dt">導(dǎo)出的數(shù)據(jù)表</param> /// <param name="dic">字段名稱,字段中文名稱</param> /// <param name="title">導(dǎo)出第一行標(biāo)題</param> /// <returns></returns> public Workbook ExportData(DataTable table, Dictionary<string, string> dic, string title = "") { title = string.IsNullOrEmpty(title) ? "導(dǎo)出數(shù)據(jù)" : title; Workbook workbook = new Workbook(); workbook.Worksheets.RemoveAt(0);//移除第一個(gè)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;//表格列數(shù) int Rownum = table.Rows.Count;//表格行數(shù) Worksheet sheet = workbook.Worksheets.Add(title); Cells cells = sheet.Cells;//單元格 //為標(biāo)題設(shè)置樣式 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;//單元格內(nèi)容自動(dòng)換行 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 標(biāo)題行 cells.Merge(0, 0, 1, Colnum);//合并單元格 cells[0, 0].PutValue(title);//填寫(xiě)內(nèi)容 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); } //生成數(shù)據(jù)行 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> /// 獲取某個(gè)表下面的所有列名和說(shuō)明 /// </summary> /// <param name="tbname">表名</param> /// <param name="orderrule">排序規(guī)則</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; }
兩個(gè)搞定了,能實(shí)現(xiàn)絕大部分的導(dǎo)出業(yè)務(wù)。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
asp.net GridView的刪除對(duì)話框的兩種方法
本來(lái)這兩種方法,我已經(jīng)掌握。但是沒(méi)有總結(jié),今天朋友突然問(wèn)題,我竟然想不起來(lái),找了半天,現(xiàn)在亡羊補(bǔ)牢,趕快寫(xiě)在博客里。2009-04-04.net連接oracle的3種實(shí)現(xiàn)方法
這篇文章介紹了.net連接oracle的3種實(shí)現(xiàn)方法,有需要的朋友可以才可以一下2013-07-07.net 通過(guò)URL推送POST數(shù)據(jù)具體實(shí)現(xiàn)
這篇文章主要介紹了.net 通過(guò)URL推送POST數(shù)據(jù)具體實(shí)現(xiàn),有需要的朋友可以參考一下2013-12-12ASP.NET小結(jié)之MVC, MVP, MVVM比較以及區(qū)別(一)
MVC, MVP和MVVM都是用來(lái)解決界面呈現(xiàn)和邏輯代碼分離而出現(xiàn)的模式。以前只是對(duì)它們有部分的了解,沒(méi)有深入的研究過(guò),對(duì)于一些里面的概念和區(qū)別也是一知半解。現(xiàn)在一邊查資料,并結(jié)合自己的理解,來(lái)談一下對(duì)于這三種模式思想的理解,以及它們的區(qū)別。歡迎各位高手拍磚。2014-05-05如何傳值在2個(gè)頁(yè)面之間 要求不刷新父頁(yè)面,并且不能用Querystring傳值
通過(guò)Cookie,因?yàn)樗瓤梢栽诜?wù)器端對(duì)其進(jìn)行操作,也可在客戶端對(duì)其進(jìn)行操作但是缺點(diǎn)是不安全,而且有時(shí)客戶端會(huì)由于安全問(wèn)題禁用Cookie!2008-12-12一步步教你在Asp.net Mvc中使用UEditor編輯器
大家都知道ueditor是百度編輯器,目前使用也比較廣泛,下面這篇文章主要是通過(guò)一步步的步驟教大家在Asp.net Mvc中使用UEditor編輯器,需要的朋友可以參考借鑒,下面來(lái)一起看看吧。2016-12-12.Net Core如何對(duì)MongoDB執(zhí)行多條件查詢
這篇文章主要介紹了.Net Core如何對(duì)MongoDB執(zhí)行多條件查詢,文中示例代碼非常詳細(xì),幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下2020-07-07