分享一个前辈的NPOIhelper
即拿即用:
首先要下载npoi的dll,此不赘述,接着添加引用:
- using NPOI.HPSF;
- using NPOI.HSSF.UserModel;
- using NPOI.SS.UserModel;
- using NPOI.SS.Util;
下面是主要方法
- public class NPOIHelper
- {
- /// <summary>
- /// DataTable导出到Excel文件
- /// </summary>
- /// <param name="dtSource">源DataTable</param>
- /// <param name="strHeaderText">表头文本</param>
- /// <param name="strFileName">保存位置</param>
- public static void DataTableToExcel(DataTable dtSource, string strHeaderText, string strFileName)
- {
- using (MemoryStream ms = DataTableToExcel(dtSource, strHeaderText))
- {
- using (FileStream fs = new FileStream(strFileName, FileMode.Create, FileAccess.Write))
- {
- byte[] data = ms.ToArray();
- fs.Write(data, , data.Length);
- fs.Flush();
- }
- }
- }
- /// <summary>
- /// DataTable导出到Excel的MemoryStream
- /// </summary>
- /// <param name="dtSource">源DataTable</param>
- /// <param name="strHeaderText">表头文本</param>
- public static MemoryStream DataTableToExcel(DataTable dtSource, string strHeaderText)
- {
- HSSFWorkbook workbook = new HSSFWorkbook();
- HSSFSheet sheet = (HSSFSheet)workbook.CreateSheet();
- #region 右击文件 属性信息
- {
- DocumentSummaryInformation dsi = PropertySetFactory.CreateDocumentSummaryInformation();
- dsi.Company = "NPOI";
- workbook.DocumentSummaryInformation = dsi;
- SummaryInformation si = PropertySetFactory.CreateSummaryInformation();
- si.Author = "文件作者信息"; //填加xls文件作者信息
- si.ApplicationName = "创建程序信息"; //填加xls文件创建程序信息
- si.LastAuthor = "最后保存者信息"; //填加xls文件最后保存者信息
- si.Comments = "作者信息"; //填加xls文件作者信息
- si.Title = "标题信息"; //填加xls文件标题信息
- si.Subject = "主题信息";//填加文件主题信息
- si.CreateDateTime = System.DateTime.Now;
- workbook.SummaryInformation = si;
- }
- #endregion
- HSSFCellStyle dateStyle = (HSSFCellStyle)workbook.CreateCellStyle();
- HSSFDataFormat format = (HSSFDataFormat)workbook.CreateDataFormat();
- dateStyle.DataFormat = format.GetFormat("yyyy-mm-dd");
- //边框
- dateStyle.BorderBottom = BorderStyle.Thin;
- dateStyle.BorderLeft = BorderStyle.Thin;
- dateStyle.BorderRight = BorderStyle.Thin;
- dateStyle.BorderTop = BorderStyle.Thin;
- //取得列宽
- int[] arrColWidth = new int[dtSource.Columns.Count];
- foreach (DataColumn item in dtSource.Columns)
- {
- arrColWidth[item.Ordinal] = Encoding.GetEncoding().GetBytes(item.ColumnName.ToString()).Length;
- }
- for (int i = ; i < dtSource.Rows.Count; i++)
- {
- for (int j = ; j < dtSource.Columns.Count; j++)
- {
- int intTemp = Encoding.GetEncoding().GetBytes(dtSource.Rows[i][j].ToString()).Length;
- if (intTemp > arrColWidth[j])
- {
- arrColWidth[j] = intTemp;
- }
- }
- }
- int rowIndex = ;
- foreach (DataRow row in dtSource.Rows)
- {
- #region 新建表,填充表头,填充列头,样式
- if (rowIndex == || rowIndex == )
- {
- if (rowIndex != )
- {
- sheet = (HSSFSheet)workbook.CreateSheet();
- }
- #region 表头及样式
- {
- HSSFRow headerRow = (HSSFRow)sheet.CreateRow();
- headerRow.HeightInPoints = ;
- headerRow.CreateCell().SetCellValue(strHeaderText);
- HSSFCellStyle headStyle = (HSSFCellStyle)workbook.CreateCellStyle();
- headStyle.Alignment = HorizontalAlignment.Center;
- HSSFFont font = (HSSFFont)workbook.CreateFont();
- font.FontHeightInPoints = ;
- font.Boldweight = ;
- headStyle.SetFont(font);
- headerRow.GetCell().CellStyle = headStyle;
- sheet.AddMergedRegion(new Region(, , , dtSource.Columns.Count - ));
- }
- #endregion
- #region 列头及样式
- {
- HSSFRow headerRow = (HSSFRow)sheet.CreateRow();
- HSSFCellStyle headStyle = (HSSFCellStyle)workbook.CreateCellStyle();
- headStyle.Alignment = HorizontalAlignment.Center;
- //边框
- headStyle.BorderBottom = BorderStyle.Thin;
- headStyle.BorderLeft = BorderStyle.Thin;
- headStyle.BorderRight = BorderStyle.Thin;
- headStyle.BorderTop = BorderStyle.Thin;
- HSSFFont font = (HSSFFont)workbook.CreateFont();
- font.FontHeightInPoints = ;
- font.Boldweight = ;
- headStyle.SetFont(font);
- foreach (DataColumn column in dtSource.Columns)
- {
- headerRow.CreateCell(column.Ordinal).SetCellValue(column.ColumnName);
- headerRow.GetCell(column.Ordinal).CellStyle = headStyle;
- //设置列宽
- sheet.SetColumnWidth(column.Ordinal, (arrColWidth[column.Ordinal] + ) * );
- }
- // headerRow.Dispose();
- }
- #endregion
- rowIndex = ;
- }
- #endregion
- #region 填充内容
- HSSFRow dataRow = (HSSFRow)sheet.CreateRow(rowIndex);
- #region 边框,样式
- HSSFCellStyle NewCellStyle = (HSSFCellStyle)workbook.CreateCellStyle();
- NewCellStyle.Alignment = HorizontalAlignment.Center;
- //边框
- NewCellStyle.BorderBottom = BorderStyle.Thin;
- NewCellStyle.BorderLeft = BorderStyle.Thin;
- NewCellStyle.BorderRight = BorderStyle.Thin;
- NewCellStyle.BorderTop = BorderStyle.Thin;
- #endregion
- foreach (DataColumn column in dtSource.Columns)
- {
- HSSFCell newCell =(HSSFCell) dataRow.CreateCell(column.Ordinal);
- string drValue = row[column].ToString();
- switch (column.DataType.ToString())
- {
- case "System.String"://字符串类型
- newCell.SetCellValue(drValue);
- newCell.CellStyle = NewCellStyle;
- break;
- case "System.DateTime"://日期类型
- System.DateTime dateV;
- System.DateTime.TryParse(drValue, out dateV);
- newCell.SetCellValue(dateV);
- newCell.CellStyle = dateStyle;//格式化显示
- break;
- case "System.Boolean"://布尔型
- bool boolV = false;
- bool.TryParse(drValue, out boolV);
- newCell.SetCellValue(boolV);
- newCell.CellStyle = NewCellStyle;
- break;
- case "System.Int16"://整型
- case "System.Int32":
- case "System.Int64":
- case "System.Byte":
- int intV = ;
- int.TryParse(drValue, out intV);
- newCell.SetCellValue(intV);
- newCell.CellStyle = NewCellStyle;
- break;
- case "System.Decimal"://浮点型
- case "System.Double":
- double doubV = ;
- double.TryParse(drValue, out doubV);
- newCell.SetCellValue(doubV);
- newCell.CellStyle = NewCellStyle;
- break;
- case "System.DBNull"://空值处理
- newCell.SetCellValue("");
- newCell.CellStyle = NewCellStyle;
- break;
- default:
- newCell.SetCellValue("");
- newCell.CellStyle = NewCellStyle;
- break;
- }
- }
- #endregion
- rowIndex++;
- }
- using (MemoryStream ms = new MemoryStream())
- {
- workbook.Write(ms);
- ms.Flush();
- ms.Position = ;
- return ms;
- }
- }
- }
后面调用这个类,如下:
- string dir = Environment.GetFolderPath(Environment.SpecialFolder.DesktopDirectory);//取得当前桌面路径
- NPOIHelper.DataTableToExcel(dt,"文档测试",dir+@"\测试.xls");
分享一个前辈的NPOIhelper的更多相关文章
- 分享一个SQLSERVER脚本(计算数据库中各个表的数据量和每行记录所占用空间)
分享一个SQLSERVER脚本(计算数据库中各个表的数据量和每行记录所占用空间) 很多时候我们都需要计算数据库中各个表的数据量和每行记录所占用空间 这里共享一个脚本 CREATE TABLE #tab ...
- 分享一个MySQL分库分表备份脚本(原)
分享一个MySQL分库备份脚本(原) 开发思路: 1.路径:规定备份到什么位置,把路径(先判断是否存在,不存在创建一个目录)先定义好,我的路径:/mysql/backup,每个备份用压缩提升效率,带上 ...
- 分享一个与ABP配套使用的代码生成器源码
点这里进入ABP系列文章总目录 分享一个与ABP配套使用的代码生成器源码 真对不起关注我博客的朋友, 因最近工作很忙, 很久没有更新博客了.以前答应把自用的代码生成器源码共享出来, 也一直没有时间整理 ...
- 分享一个常用Adb命令
分享一个常用Adb命令 首先 首先感谢@xuxu的常用adb命令,收益良多,但是已经不能满足于我,所以补充了下. 再者 好久没发帖了,最近论坛老司机们都在讨论/总结,我就用这个干货回报吧. 最后 基于 ...
- 福利到~分享一个基于jquery的智能提示控件intellSeach.js
一.需求 我们经常会遇到[站内搜索]的需求,为了提高用户体验,我们希望能做到像百度那样的即时智能提示.例如:某公司人事管理系统,想搜索李XX,只要输入“李”,系统自然会提示一些姓李的员工,这样方便用户 ...
- 分享一个oraclehelper
分享一个拿即用的oraclehelper 首先要引用本机中的oralce access,如果是64位的话,也必须是64位运行,不然会报连接为空connection 等于null. using Orac ...
- 分享一个ruby网站 | 菜鸟教程
http://www.runoob.com/ruby/ruby-tutorial.html 分享一个ruby网站.
- 分享一个批量导出当前实例下的所有linkedserver脚本
分享一个批量导出当前实例下的所有linkedserver脚本 很多时候,我们都需要导出实例下面的登录用户,job,linkedserver等等 导出job比较复杂,下午写了一个脚本把所有的linked ...
- 分享一个漂亮的ASP.NET MVC界面框架
本文分享一个插件化的界面框架,该框架提供了用户.角色.权限管理功能,也提供了插件的管理和插件中心.下图是该界面框架的样式(全部源码和原理介绍下一篇分享,推荐越多,源码放的越早,呵呵). 要使用该界面框 ...
随机推荐
- Uva 2034
求定积分 (结果当时我没看到平均值) //正常多项式求 #include<iostream> #include<cstdio> #include<cmath> us ...
- StartUML反向(逆向)Java工程通过代码生成类图
在软件工程中,通过都是先了详细设计,然后按照详细设计来进行开发.在编写详细设计的时候,通常都会画一些类图.时序图.流程图等等UML设计,然后通过uml类图生成代码,这个属于正向工程生成代码,然而在实 ...
- 【GWAS文献解读】疟原虫青蒿素抗药性的全基因组关联分析
英文名:Genetic architecture of artemisinin-resistant Plasmodium falciparum 中文名:疟原虫青蒿素抗药性的全基因组关联分析 期刊:Na ...
- %格式化和format格式化--python
格式符 %[(name)][floags][width].[precision]typecode (name) 可选,用于选择指定的key flags 可选,可提供的值有: · + 右对齐,整数前加正 ...
- AngularJS 分页
前端源码: <div> <h1>列表页33</h1> <table> <thead> <tr><td>CandiID ...
- canvas 画板
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...
- 第一个JSP
还是大一暑假学的Java,知识掌握了第一阶段的Java基础知识, 后面想自己进阶第二阶段,学习JavaWeb,一直拖到现在直接从Java第二阶段写了~~~ 希望指正: 这次主要还是第一个Hello W ...
- SpringMVC与Ajax交互
1 springmvc和ajax的交互 1.1 请求字符串响应json 客户端发送的数据:key=value&key1=value1 响应回来:json 1.1.1json的支持jar包 1 ...
- 理解JavaScript中的作用域和上下文
JavaScript对于作用域(Scope)和上下文(Context)的实现是这门语言的一个非常独到的地方,部分归功于其独特的灵活性. 函数可以接收不同的的上下文和作用域.这些概念为JavaScrip ...
- B树(B-Tree)的由来、数据结构、基本操作以及数据库索引的应用
B树是为磁盘存储而专门设计的一类平衡搜索树,B树的高度仅随着它所包含的节点数按对数增长,不过因为单个节点可以包含多个关键字,所以对数的底数可以比较大,实际应用中一般是50~2000,给个直观的数字,一 ...