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 ...
随机推荐
- Python12/11--盒子的显隐/布局/z-index/流式布局思想
1.盒子的显隐 display:none 在页面中不占位,采用定位布局后,显示隐藏都不会影响其他标签,不需要用动画处理时,一般用这个 opacoity : 0 在页面中占位,采 ...
- drf3 Serializers 序列化组件
为什么要用序列化组件 做前后端分离的项目,我们前后端交互一般都选择JSON数据格式,JSON是一个轻量级的数据交互格式. 给前端数据的时候都要转成json格式,那就需要对从数据库拿到的数据进行序列化. ...
- Struts2学习第三天——保存登陆信息及数据校验
在JSP中服务器端保存数据的作用域通常有request.session.application,它们对应的Servlet API分别是HttpServletRquerst.HttpSession.Se ...
- SQL Server CTE 递归查询全解 -- 转 学习
在TSQL脚本中,也能实现递归查询,SQL Server提供CTE(Common Table Expression),只需要编写少量的代码,就能实现递归查询,本文详细介绍CTE递归调用的特性和使用示例 ...
- 带权单源最短路[稀疏图](Dijkstra)
因为是稀疏图,所以应当选择邻接表来存储 构造一个邻接表 这只是我的构造方法,有很多种更好的构造方法,大家可以自己去构造 typedef int vertex; typedef int WeightTy ...
- Navicat for MYSQL 断网时本地连接无法打开,2005错误
Navicat for MYSQL 断网时本地连接无法打开,2005错误 NO1 提示下图: NO2 解决方法: (1)选中本地连接,右键 连接属性 (2) 将 主机名或IP地址 这一栏改为 127. ...
- subarray sum
public class Solution { /* * @param nums: A list of integers * @return: A list of integers includes ...
- Linux下gcc编译控制动态库导出函数小结
根据说明文档“How To Write Shared Libraries"介绍, 有四种方法: 1. 在方法声明定义时,加修饰:__attribute__((visibility(" ...
- C# Autofac集成之Framework WebAPI
Web API 2集成需要Autofac.WebApi2 NuGet包. Web API集成需要Autofac.WebApi NuGet包. Web API集成为控制器,模型绑定器和操作过滤器提供了依 ...
- B树之C语言实现(包含查找、删除、插入)
B树的定义 一棵m阶B树(Balanced Tree of order m),或为空树,或为满足下列特性对的m叉树. 树中每个结点最多含有m棵子树. 若根结点不是叶子结点,则至少有2个子树. 除根结点 ...