无为清净楼资源网 Design By www.qnjia.com
最近做了个项目,客户对导出excel功能情有独钟,几乎要求每一个列表数据都支持导出excel功能,为了避免代码重复,万能粉嫩的小码农开发了万能导出QAQ.
导出Excel无非就是取出数据,然后利用Aspose.Cells插件填充到Excel文件中,DataTable类型的数据是最适合填充Excel不过了.唯一的问题就是DataTable数据的列头一般是英文,突然就想出了利用SQL Server每一列的说明来替换掉英文列头的方法,我太TM机智了.
/// <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,导出
无为清净楼资源网 Design By www.qnjia.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
无为清净楼资源网 Design By www.qnjia.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年11月16日
2024年11月16日
- 模拟之声慢刻CD《柏林之声4》[正版CD低速原抓WAV+CUE]
- 李宗盛 《李宗盛经典金曲》[WAV+CUE][1G]
- 周华健《粤语精选》[WAV+CUE][1G]
- 蔡婧2024《天空》HQCDII头版限量编号[WAV+CUE][1G]
- 陈奂仁.2011-谁是陈奂仁【BBS】【FLAC分轨】
- 群星.2024-幻乐森林影视原声带【韶愔音乐】【FLAC分轨】
- 黎明.1999-向往金色的黎明新歌+精选2CD【环球】【WAV+CUE】
- 发烧女声Méav《美芙的祈祷》发烧女声 [WAV+CUE][820M]
- 雷婷 《我的爱回不来》紫银合金AQCD [WAV+CUE][1G]
- 群星 DTS《天籁之音·唱醉了草原》2CD[WAV分轨][1.6G]
- 魔兽世界wlk毁灭术一键输出宏是什么 wlk毁灭术一键输出宏介绍
- 三国志8重制版无法与武将交流怎么办 无法与武将交流解决方法一览
- 三国志8重制版恶名怎么消除 恶名影响与消除方法介绍
- 模拟之声慢刻CD《柏林之声5》2019[原抓WAV+CUE]
- AlexandraSoumm-Parisestunefte(2024)[24Bit-96kHz]FLAC