C#npoi导出excel一些自己的看法
2018-06-18 04:21:47来源:未知 阅读 ()
之前转过一篇类似的文章,那个是用C#自带的excel类操作Excel的,还有一种在c#上操作excel的方法便是npoi了,npoi是poi的C#版本。
npoi操作excel有两种形式,一种是hssf和xssf。hssf是用来生成excel2003之前的版本,生成的excel后缀是“.xls”,而xssf是excel2007的版本,操作的excel的后缀是“.xlsx”。
npoi中常用的类型:
XSSF/HSSFWorkbook:excel文件的工作簿,
Isheet:excel文件的工作簿中的工作表,
IRow:excel文件的工作簿中的工作表中的行,
ICell:excel文件的工作簿中的工作表中的行中的单元格。
举一个简单的导出excel的方法
public static IWorkbook TableToExcel(DataTable dt, string fileExt = ".xlsx") { IWorkbook workbook; if (fileExt == ".xlsx") { workbook = new XSSFWorkbook(); } else if (fileExt == ".xls") { workbook = new HSSFWorkbook(); } else { workbook = null; } if (workbook == null) { return null; } ISheet sheet = string.IsNullOrEmpty(dt.TableName) ? workbook.CreateSheet("Sheet1") : workbook.CreateSheet(dt.TableName); //表头 IRow row = sheet.CreateRow(0); for (int i = 0; i < dt.Columns.Count; i++) { ICell cell = row.CreateCell(i); cell.SetCellValue(dt.Columns[i].ColumnName); } //数据 for (int i = 0; i < dt.Rows.Count; i++) { IRow row1 = sheet.CreateRow(i + 1); for (int j = 0; j < dt.Columns.Count; j++) { ICell cell = row1.CreateCell(j); cell.SetCellValue(dt.Rows[i][j].ToString()); } } //设置宽度 for (int i = 0; i < dt.Columns.Count; i++) { int length = Encoding.Default.GetBytes(row.GetCell(i).ToString()).Length; sheet.SetColumnWidth(i, (length + 2) * 256); } return workbook; }
//生成excel:
using (MemoryStream ms = new MemoryStream())
{
workbook.Write(ms);
var buffer = ms.GetBuffer();
ms.Close();
return File(buffer, "application/vnd.ms-excel", "个人提成补录模板.xls");
}
如果要更改单元格颜色的样式,可以用下面的方法:
ICellStyle style = workbook.CreateCellStyle(); style.FillPattern = FillPattern.SolidForeground;//很重要 style.FillBackgroundColor = NPOI.HSSF.Util.HSSFColor.Red.Index; style.FillForegroundColor = NPOI.HSSF.Util.HSSFColor.Red.Index; IRow excelRow = workbook.GetSheetAt(0).GetRow(0); for (int i = 0; i <= 5; i++) { excelRow.GetCell(i).CellStyle = style; } excelRow.GetCell(22).CellStyle = style; excelRow.GetCell(19).CellStyle = style; excelRow.GetCell(8).CellStyle = style;
改颜色纠结了好久,也查了好多资料,网上有好多用cell.setcellstyle()这个方法的,我试了一下,根本没有,而且好多都是那样写的,不知道是java的还是啥的,应该不是.net的。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:mvc 实现超时弹窗后跳转
- Spire.Cloud.SDK for Java 合并、拆分Excel单元格 2020-06-09
- 「starter推荐」简单高效Excel 导出工具 2020-06-08
- 【Java-jxl插件】【Excel文件读写报错】jxl.read.biff.BiffE 2020-06-07
- excel如何分别实现按行读和按列读呢 2020-06-06
- Dubbo源码阅读-服务导出 2020-05-29
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash