c# Datatable导出Excel
using NPOI.SS.UserModel; using NPOI.XSSF.UserModel; using System; using System.Collections.Generic; using System.Data; using System.IO; using System.Linq; using Newtonsoft.Json; namespace EasyFrame.Common { /// <summary> ///title调用信息 /// </summary> public class ChartTitle { /// <summary> /// 调用名 /// </summary> public string CallName { get; set; } /// <summary> /// 标头信息 /// </summary> public List<ChartName> SetNameList { get; set; } } public class ChartName { /// <summary> /// 一级标头 /// </summary> public string Name { get; set; } /// <summary> /// 二级标头 /// </summary> public List<string> ChartChildNameList { get; set; } } public class ExcelHelper { // /// <summary> /// Datatable导出Excel /// </summary> /// <param name="dt">数据</param> /// <param name="list">表头</param> /// <param name="counts">总条数</param> /// <param name="filePath">保存地址</param> /// <returns></returns> public static MemoryStream WriteExcel(DataTable dt, List<ChartTitle> objlist, string filePath) { var list = objlist.FirstOrDefault(a => a.CallName == "ccc").SetNameList; ) { XSSFWorkbook book = new XSSFWorkbook(); NPOI.SS.UserModel.ISheet sheet = book.CreateSheet(dt.TableName); ICell cell = null; ICellStyle style = book.CreateCellStyle(); IFont font = book.CreateFont();//创建字体样式 IFont fonts = book.CreateFont();//创建字体样式 IFont fontss = book.CreateFont();//创建字体样式 font.Color = NPOI.HSSF.Util.HSSFColor.Red.Index;//设置字体颜色 ICellStyle styles = book.CreateCellStyle(); //红色 fonts.Color = NPOI.HSSF.Util.HSSFColor.Green.Index; ICellStyle styless = book.CreateCellStyle(); //绿色 fontss.Color = NPOI.HSSF.Util.HSSFColor.Blue.Index; ICellStyle stylesss = book.CreateCellStyle(); //蓝色 styless.SetFont(fonts); styles.SetFont(font); stylesss.SetFont(fontss); style.Alignment = HorizontalAlignment.Center; NPOI.SS.UserModel.IRow row1 = sheet.CreateRow(); NPOI.SS.UserModel.IRow row2 = sheet.CreateRow(); var row = row1; ;//记录列 var d = true;//是否第一次加载到二级表单 #region 创建表头 //两行单列 ; i < list.Count; i++) { if (!d) { row = row1; d = true; } if (list[i].ChartChildNameList == null) { cell = row.CreateCell(num); sheet.SetColumnWidth(num, * ); cell.SetCellValue(list[i].Name); cell.CellStyle = style; sheet.AddMergedRegion(, , num, num)); num++; continue; } //两行多列 var count = list[i].ChartChildNameList.Count; //列数 cell = row.CreateCell(num); cell.SetCellValue(list[i].Name); cell.CellStyle = style; sheet.AddMergedRegion(, , num, count + num - )); if (d) { d = false; row = row2; } ; ); ; j < count; j++) { sheet.SetColumnWidth(num + t, * ); cell = row.CreateCell(num + t); cell.SetCellValue(list[i].ChartChildNameList[j]); cell.CellStyle = style; t++; } num = num + count; } #endregion 创建表头 #region 写入数据 ;//记录列数 ;//记录行数 filePath = string.Format(filePath, "XXX"); #region 导出操作 ][].ToString()); foreach (var item in data1) { NPOI.SS.UserModel.IRow rows = sheet.CreateRow(clouns + ); customs = ; rows.CreateCell(customs).SetCellValue(Convert.ToString(item.No)); customs++; rows.CreateCell(customs).SetCellValue(Convert.ToString(item.LotteryOpenNo)); customs++; ; i < item.Wan.Length; i++) { ] == item.Wan[i].ToString()) { cell = rows.CreateCell(customs); cell.SetCellValue(item.Wan[i]); cell.CellStyle = styles; customs++; } else { rows.CreateCell(customs).SetCellValue(item.Wan[i]); customs++; } } ; j < item.Qian.Length; j++) { ] == item.Qian[j].ToString()) { cell = rows.CreateCell(customs); cell.SetCellValue(item.Qian[j]); cell.CellStyle = styles; customs++; } else { rows.CreateCell(customs).SetCellValue(item.Qian[j]); customs++; } } ; k < item.Bai.Length; k++) { ] == item.Bai[k].ToString()) { cell = rows.CreateCell(customs); cell.SetCellValue(item.Bai[k]); cell.CellStyle = styles; customs++; } else { rows.CreateCell(customs).SetCellValue(item.Bai[k]); customs++; } } ; l < item.Shi.Length; l++) { ] == (item.Shi[l].ToString())) { cell = rows.CreateCell(customs); cell.SetCellValue(item.Shi[l]); cell.CellStyle = styles; customs++; } else { rows.CreateCell(customs).SetCellValue(item.Shi[l]); customs++; } } ; m < item.Ge.Length; m++) { ] == (item.Ge[m].ToString())) { cell = rows.CreateCell(customs); cell.SetCellValue(item.Ge[m]); cell.CellStyle = styles; customs++; } else { rows.CreateCell(customs).SetCellValue(item.Ge[m]); customs++; } } ; n < item.Fen.Length; n++) { if (item.LotteryOpenNo.Contains(item.Fen[n].ToString())) { cell = rows.CreateCell(customs); cell.SetCellValue(item.Fen[n]); cell.CellStyle = styles; customs++; } else { rows.CreateCell(customs).SetCellValue(item.Fen[n]); customs++; } } clouns++; } #endregion #endregion 写入数据 // 写入到客户端 using (System.IO.MemoryStream ms = new System.IO.MemoryStream()) { book.Write(ms); using (FileStream fs = new FileStream(filePath, FileMode.Create, FileAccess.Write)) { byte[] data = ms.ToArray(); fs.Write(data, , data.Length); fs.Flush(); } book = null; return ms; } } return null; } } }
c# Datatable导出Excel的更多相关文章
- asp.net DataTable导出Excel 自定义列名
1.添加引用NPOI.dll 2.cs文件头部添加 using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; using System.IO; 3.代码如 ...
- Datatable导出Excel
; IRow headerRow = sheet.CreateRow(); ; ; ; iRowIndex++; } ; i < icolIndex; i++) { sheet.AutoSize ...
- C# DataTable导出EXCEL后身份证、银行卡号等长数字信息显示乱码解决
在DataTable导出EXCEL后发现有些格式显示有问题,比如身份证.银行卡号等大于11位的数字显示为科学计数法.13681-1等 带中划线的两段数字显示为日期格式等. 处理方法如下: public ...
- 【转】C# DataTable 导出 Excel 进阶 多行表头、合并单元格、中文文件名乱码
本文原创地址:http://blog.csdn.net/ranbolwb/article/details/8083983 ,转载请保留本行. 本例子是上一篇 DataTable 导出 Excel 的进 ...
- DataTable 更改在有数据列的类型方法+DataTable 导出excel功能
/// <summary> /// 导出功能 /// </summary> /// <param name="sender"></para ...
- C# Datatable导出Excel方法
C# 导出Excel方法 先引用下System.IO;System.data; 具体函数如下: public static bool ExportCSV(DataTable dt, string f ...
- NPOI DataTable导出excel
/// <summary> /// DataTable导出到Excel文件 /// </summary> /// <param name="dtSource&q ...
- WinForm 使用 NPOI 2.2.1从datatable导出Excel
最新的NOPI应该是2.3了,但在官网上还是2.2.1. 也是第一次使用NPOI来导出Excel文件. 在写的时候搜不到2.2.1的教程,搜了一个2.2.0的教程. 不过也没什么问题,NPOI是真的方 ...
- 【ASP.NET】DataTable导出EXCEL,弹窗提示下载保存(完整代码)
//新建ASPX protected void Page_Load(object sender, EventArgs e) { DataTable dt = new DataTable(); Data ...
随机推荐
- orabbix监控oracle
Orabbix 是一个用来监控 Oracle 数据库实例的 Zabbix 插件.下载地址: http://www.smartmarmot.com/product/orabbix/download/ O ...
- JAVA核心问题(一)反射之引言 构造函数
反射,简单来说,就是在运行时获取Class对象的所有属性和方法,无论公有私有.虽然是一个基础问题,在这里还是全面的记录一下,认真对待! 获取构造函数 构造函数大致分为两种,public和非public ...
- python之路(三)-深浅拷贝
深浅拷贝用法来自copy模块. 导入模块:import copy 浅拷贝:copy.copy 深拷贝:deepcopy 字面理解:浅拷贝指仅仅拷贝数据集合的第一层数据,深拷贝指拷贝数据集合的所有层.所 ...
- 使用pwm进行呼吸灯的设计
本文源码已经上传至csdn: 程序源码如下; #define LEDC_IO_0 (2) esp_err_t app_main() { ledc_timer_config_t ledc_timer = ...
- 带参数的main函数以及execl函数的应用
---恢复内容开始--- 代码1:(带参main函数) #include<stdio.h> int main(int number, char *parameter[]) { ; prin ...
- Request参数值自动去空格
/// <summary> /// TypeTrimHelper /// </summary> public static class TypeTrimHelper { /// ...
- [UWP]使用Popup构建UWP Picker
在上一篇博文<[UWP]不那么好用的ContentDialog>中我们讲到了ContentDialog在复杂场景下使用的几个令人头疼的弊端.那么,就让我们在这篇博文里开始愉快的造轮子之旅吧 ...
- Mybatis框架三:DAO层开发、Mapper动态代理开发
这里是最基本的搭建:http://www.cnblogs.com/xuyiqing/p/8600888.html 接下来做到了简单的增删改查:http://www.cnblogs.com/xuyiqi ...
- 动态页面技术EL
1.EL概述: EL表达式可以嵌入再JSP页面内部,减少JSP脚本的编写 EL出现的目的是要替代JSP页面中脚本的编写 EL最重要的作用就是从域中取出数据: 引入: JSP中<%=request ...
- ElasticSearch核心知识总结(二)
如何超出扩容极限,以及如何提升容错性 primary&replica自动负载均衡,6个shared,3个primary,3个replica,随着机器扩容,会被均衡分配到多台机器上 6个shar ...