利用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 Core Middleware實(shí)現(xiàn)方法
這篇文章主要介紹了探究ASP.NET Core Middleware實(shí)現(xiàn)方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-02-02
asp.net GridView的刪除對(duì)話框的兩種方法
本來(lái)這兩種方法,我已經(jīng)掌握。但是沒(méi)有總結(jié),今天朋友突然問(wèn)題,我竟然想不起來(lái),找了半天,現(xiàn)在亡羊補(bǔ)牢,趕快寫(xiě)在博客里。2009-04-04
.NET或.NET Core Web APi基于tus協(xié)議實(shí)現(xiàn)斷點(diǎn)續(xù)傳的示例
這篇文章主要介紹了.NET或.NET Core Web APi基于tus協(xié)議實(shí)現(xiàn)斷點(diǎn)續(xù)傳的示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11
如何使用Python實(shí)現(xiàn)阿拉伯?dāng)?shù)字轉(zhuǎn)換成中國(guó)漢字
本文提供了一個(gè)Python代碼示例,用于將阿拉伯?dāng)?shù)字轉(zhuǎn)換為中文漢字表示,代碼定義了數(shù)字到漢字的映射表,并實(shí)現(xiàn)了處理不同位數(shù)(如個(gè)、十、百、千、萬(wàn)等)的函數(shù),特別地,處理方式包括對(duì)大數(shù)字的分解和轉(zhuǎn)換,以及對(duì)連續(xù)零的特殊處理,感興趣的朋友跟隨小編一起看看吧2024-09-09
SqlDataReader指定轉(zhuǎn)換無(wú)效的解決方法
這篇文章主要為大家詳細(xì)介紹了SqlDataReader指定轉(zhuǎn)換無(wú)效的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06
WebForm獲取checkbox選中的值(幾個(gè)簡(jiǎn)單的示例)
WebForm中用checkbox的地方挺多的,下面寫(xiě)了幾個(gè)簡(jiǎn)單的例子,方便以后學(xué)習(xí)使用2014-07-07
ASP.NET MVC 中實(shí)現(xiàn)基于角色的權(quán)限控制的處理方法
在ASP.NET MVC中,通過(guò)使用其所提供的內(nèi)置2013-03-03
驗(yàn)證一個(gè)ASP.NET應(yīng)用程序和頁(yè)面的生命周期的實(shí)現(xiàn)代碼
我們知道ASP.NET Page的生命周期實(shí)際上是ASP.NET Application的生命周期的一部分。這個(gè)周期經(jīng)歷了HTTP Module => HTTP Handler => ASP.NET Page => Http Module這樣一個(gè)過(guò)程2012-04-04

