C# DataGridview用NPOI导出Excel文件
导出excel我用的是nuget 的NPOI,直接在项目中添加的,引用到项目中,下面是截图:
下面我把ExcelHelper贴出来
- public static class ExcelHelper
- {
- public static void ExportToExcel(DataTable dt)
- {
- ExportToExcelData(dt);
- }
- public static DataTable ToDataTable(this DataGridView myDGV)
- {
- DataTable dt = new DataTable();
- for (int i = ; i < myDGV.ColumnCount; i++)
- {
- dt.Columns.Add(myDGV.Columns[i].HeaderText);
- }
- //写入数值
- for (int r = ; r < myDGV.Rows.Count; r++)
- {
- List<object> values = new List<object>();
- for (int i = ; i < myDGV.ColumnCount; i++)
- {
- values.Add(myDGV.Rows[r].Cells[i].Value);
- }
- dt.Rows.Add(values .ToArray());
- }
- return dt;
- }
- #region 导出
- /// <summary>
- /// 数据导出
- /// </summary>
- /// <param name="data"></param>
- /// <param name="sheetName"></param>
- public static void ExportToExcelData(this DataTable data)
- {
- ExportToExcel(data, "Sheet1");
- }
- /// <summary>
- /// 数据导出
- /// </summary>
- /// <param name="data"></param>
- /// <param name="sheetName"></param>
- public static void ExportToExcel(this DataTable data, string sheetName)
- {
- SaveFileDialog fileDialog = new SaveFileDialog();
- //fileDialog.Filter = "Excel(97-2003)|*.xls|Excel(2007-2013)|*.xlsx";
- fileDialog.Filter = "Excel|*.xls|Excel|*.xlsx";
- if (fileDialog.ShowDialog() == System.Windows.Forms.DialogResult.Cancel)
- {
- return;
- }
- IWorkbook workbook = new XSSFWorkbook();
- ISheet sheet = workbook.CreateSheet(sheetName);
- IRow rowHead = sheet.CreateRow();
- //填写表头
- for (int i = ; i < data.Columns.Count; i++)
- {
- rowHead.CreateCell(i, CellType.String).SetCellValue(data.Columns[i].ColumnName.ToString());
- }
- //填写内容
- for (int i = ; i < data.Rows.Count; i++)
- {
- IRow row = sheet.CreateRow(i + );
- for (int j = ; j < data.Columns.Count; j++)
- {
- row.CreateCell(j, CellType.String).SetCellValue(data.Rows[i][j].ToString());
- }
- }
- for (int i = ; i < data.Columns.Count; i++)
- {
- sheet.AutoSizeColumn(i);
- }
- using (FileStream stream = File.OpenWrite(fileDialog.FileName))
- {
- workbook.Write(stream);
- stream.Close();
- }
- MessageBox.Show("导出数据成功!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
- GC.Collect();
- }
- #endregion
- #region 导入
- /// <summary>
- /// 导入的文件名
- /// </summary>
- /// <param name="fileName"></param>
- /// <returns></returns>
- public static DataSet ExcelToDataSet(string fileName)
- {
- return ExcelToDataSet(fileName, true);
- }
- /// <summary>
- /// 返回dataset
- /// </summary>
- /// <param name="fileName"></param>
- /// <param name="firstRowAsHeader"></param>
- /// <returns></returns>
- public static DataSet ExcelToDataSet(string fileName, bool firstRowAsHeader)
- {
- int sheetCount = ;
- return ExcelToDataSet(fileName, firstRowAsHeader, out sheetCount);
- }
- /// <summary>
- /// 返回dataset
- /// </summary>
- /// <param name="fileName">文件名</param>
- /// <param name="firstRowAsHeader">文件头</param>
- /// <param name="sheetCount">内容</param>
- /// <returns></returns>
- public static DataSet ExcelToDataSet(string fileName, bool firstRowAsHeader, out int sheetCount)
- {
- using (DataSet ds = new DataSet())
- {
- using (FileStream fileStream = new FileStream(fileName, FileMode.Open, FileAccess.Read))
- {
- IWorkbook workbook = WorkbookFactory.Create(fileStream);
- IFormulaEvaluator evaluator = WorkbookFactory.CreateFormulaEvaluator(workbook);
- sheetCount = workbook.NumberOfSheets;
- for (int i = ; i < sheetCount; ++i)
- {
- ISheet sheet = workbook.GetSheetAt(i);
- DataTable dt = ExcelToDataTable(sheet, evaluator, firstRowAsHeader);
- ds.Tables.Add(dt);
- }
- return ds;
- }
- }
- }
- /// <summary>
- /// 返回DataTable
- /// </summary>
- /// <param name="sheet"></param>
- /// <param name="evaluator"></param>
- /// <param name="firstRowAsHeader"></param>
- /// <returns></returns>
- private static DataTable ExcelToDataTable(ISheet sheet, IFormulaEvaluator evaluator, bool firstRowAsHeader)
- {
- if (firstRowAsHeader)
- {
- return ExcelToDataTableFirstRowAsHeader(sheet, evaluator);
- }
- else
- {
- return ExcelToDataTable(sheet, evaluator);
- }
- }
- private static DataTable ExcelToDataTableFirstRowAsHeader(ISheet sheet, IFormulaEvaluator evaluator)
- {
- try
- {
- using (DataTable dt = new DataTable())
- {
- IRow firstRow = sheet.GetRow();
- int cellCount = GetCellCount(sheet);
- for (int i = ; i < cellCount; i++)
- {
- if (firstRow.GetCell(i) != null)
- {
- dt.Columns.Add(firstRow.GetCell(i).StringCellValue ?? string.Format("F{0}", i + ), typeof(string));
- }
- else
- {
- dt.Columns.Add(string.Format("F{0}", i + ), typeof(string));
- }
- }
- for (int i = ; i <= sheet.LastRowNum; i++)
- {
- IRow row = sheet.GetRow(i);
- DataRow dr = dt.NewRow();
- FillDataRowByRow(row, evaluator, ref dr);
- dt.Rows.Add(dr);
- }
- dt.TableName = sheet.SheetName;
- return dt;
- }
- }
- catch (Exception ex)
- {
- MessageBox.Show(ex.Message);
- return null;
- }
- }
- private static DataTable ExcelToDataTable(ISheet sheet, IFormulaEvaluator evaluator)
- {
- using (DataTable dt = new DataTable())
- {
- if (sheet.LastRowNum != )
- {
- int cellCount = GetCellCount(sheet);
- for (int i = ; i < cellCount; i++)
- {
- dt.Columns.Add(string.Format("F{0}", i), typeof(string));
- }
- for (int i = ; i < sheet.FirstRowNum; ++i)
- {
- DataRow dr = dt.NewRow();
- dt.Rows.Add(dr);
- }
- for (int i = sheet.FirstRowNum; i <= sheet.LastRowNum; i++)
- {
- IRow row = sheet.GetRow(i);
- DataRow dr = dt.NewRow();
- FillDataRowByRow(row, evaluator, ref dr);
- dt.Rows.Add(dr);
- }
- }
- dt.TableName = sheet.SheetName;
- return dt;
- }
- }
- /// <summary>
- /// 填充数据
- /// </summary>
- /// <param name="row"></param>
- /// <param name="evaluator"></param>
- /// <param name="dr"></param>
- private static void FillDataRowByRow(IRow row, IFormulaEvaluator evaluator, ref DataRow dr)
- {
- if (row != null)
- {
- for (int j = ; j < dr.Table.Columns.Count; j++)
- {
- ICell cell = row.GetCell(j);
- if (cell != null)
- {
- switch (cell.CellType)
- {
- case CellType.Blank:
- {
- dr[j] = DBNull.Value;
- break;
- }
- case CellType.Boolean:
- {
- dr[j] = cell.BooleanCellValue;
- break;
- }
- case CellType.Numeric:
- {
- if (DateUtil.IsCellDateFormatted(cell))
- {
- dr[j] = cell.DateCellValue;
- }
- else
- {
- dr[j] = cell.NumericCellValue;
- }
- break;
- }
- case CellType.String:
- {
- dr[j] = cell.StringCellValue;
- break;
- }
- case CellType.Error:
- {
- dr[j] = cell.ErrorCellValue;
- break;
- }
- case CellType.Formula:
- {
- cell = evaluator.EvaluateInCell(cell) as HSSFCell;
- dr[j] = cell.ToString();
- break;
- }
- default:
- throw new NotSupportedException(string.Format("Unsupported format type:{0}", cell.CellType));
- }
- }
- }
- }
- }
- /// <summary>
- /// 获取单元格
- /// </summary>
- /// <param name="sheet"></param>
- /// <returns></returns>
- private static int GetCellCount(ISheet sheet)
- {
- int firstRowNum = sheet.FirstRowNum;
- int cellCount = ;
- for (int i = sheet.FirstRowNum; i <= sheet.LastRowNum; ++i)
- {
- IRow row = sheet.GetRow(i);
- if (row != null && row.LastCellNum > cellCount)
- {
- cellCount = row.LastCellNum;
- }
- }
- return cellCount;
- }
- #endregion
- }
如果DataGridview的数据源有多余的列,我们可以用扩展方法,把dataGridView转成DataTable,ExcelHelper中有,但是我拿出来,需要自己注意下。
- /// <summary>
- /// DataGridView转DataTable的扩展方法
- /// </summary>
- /// <param name="myDGV"></param>
- /// <returns></returns>
- public static DataTable ToDataTable(this DataGridView myDGV)
- {
- DataTable dt = new DataTable();
- for (int i = ; i < myDGV.ColumnCount; i++)
- {
- dt.Columns.Add(myDGV.Columns[i].HeaderText);
- }
- //写入数值
- for (int r = ; r < myDGV.Rows.Count; r++)
- {
- List<object> values = new List<object>();
- for (int i = ; i < myDGV.ColumnCount; i++)
- {
- values.Add(myDGV.Rows[r].Cells[i].Value);
- }
- dt.Rows.Add(values .ToArray());
- }
- return dt;
- }
- #endregion
导出按钮事件,可以直接写:
- if (dgBoxInData.Rows.Count > )
- {
- ExcelHelper.ExportToExcel(dgBoxInData.ToDataTable());//Run
- }
C# DataGridview用NPOI导出Excel文件的更多相关文章
- 使用NPOI导出Excel文件
使用NPOI导出Excel文件,本实例使用了ASP.NET MVC. 1.使用NPOI导出Excel文件 实例:导出商品列表. 要求:1.通过NPOI导出导出商品列表信息: 2.使用Excel函数计算 ...
- 关于NPOI导出excel文件(xls和xlsx两种格式)提示格式不符的问题
这两天在做导出excel文件的时候遇到这个问题 本来我导出的格式是xlsx格式的,但是下载得到的文件格式变成了xls, 一开始以为是返回的contenttype设置错了 return File(ms, ...
- 基于Vue + axios + WebApi + NPOI导出Excel文件
一.前言 项目中前端采用的Element UI 框架, 远程数据请求,使用的是axios,后端接口框架采用的asp.net webapi,数据导出成Excel采用NPOI组件.其业务场景,主要是列表页 ...
- C# 未安装Office环境下使用NPOI导出Excel文件
1.NuGet直接安装NPOI程序包: 2. using NPOI.XSSF.UserModel; 3.导出Excel代码: private void TsbExport2ExcelClick(obj ...
- asp.net Mvc 使用NPOI导出Excel文件
1.新建MVC项目,新建控制器.视图 添加控制器: 添加视图(将使用布局页前面的复选框里的勾勾去掉) 2.在Models里新建一个类 public class Shop { /// <summa ...
- 使用 NPOI 导出 Excel 文件
[NPOI简介] NPOI 是 POI 项目的 .NET 版本.POI是一个开源的Java读写Excel.WORD等微软OLE2组件文档的项目. 使用 NPOI 你就可以在没有安装 Office 或者 ...
- NPOI导出Excel文件,对单元格的一些设置
HSSFWorkbook book = new HSSFWorkbook(); MemoryStream ms = new MemoryStream(); ISheet sheet = book.Cr ...
- DataGridView如何快速导出Excel
从DataGridView或DataTable导出Excel文件,为了按照数据类型设置单元格格式,导出Excel时速度都比较慢,一直找不到好的办法. 最后从外文网站上找到解决办法,使用ws.get_R ...
- c# datagridview导出Excel文件 问题
今天vs2010c#开发做datagridview导出Excel文件时,发现一个问题,和大家探讨一下: 第一种方式:写流的方式 private void button_Excel_Click(obje ...
随机推荐
- javascript技巧总结
1.删除前后空格 String.prototype.trim = function () { return this.replace(/(^[ | ])|([ | ]$)/g, "" ...
- php的数组变量
数组就是存储同一类型的多个变量的 一种特殊的类型 php的数组有两种形态 1.普通类型 eg:$cars = array("Volvo","BMW"," ...
- OOAD之面向对象设计原则
学习这个设计模式 真的觉得很抽象,只有自己多多的领会! 在很多时候,很多的知识都会觉得讲起来是很矛盾的. 本章目标 1 掌握内聚度和耦合度的概念 2 掌握面向对象设计原则 (一)如何衡量软件设计的质 ...
- sql典例分析
1. 条件过滤 & Having 表结构 #tab_a #tab_b 表关系 tab_a.id = tab_b.relation_id 表数据 需求 查新把tab_a的ID对应的表tab_b的 ...
- [转]VS 2010 : 如何开发和部署Outlook 2010插件(Add-in)
本文转自:https://www.cnblogs.com/chenxizhang/archive/2010/05/08/1730766.html 概述: 这篇文章,我将通过一个简单的例子,给大家分享一 ...
- [转]Enabling CRUD Operations in ASP.NET Web API 1
本文转自:https://docs.microsoft.com/en-us/aspnet/web-api/overview/older-versions/creating-a-web-api-that ...
- C# BBcode 转 Markdown
本文告诉大家一个简单的方法从 BBcode 转为 Markdown 本文的方法都是使用正则转换,现在支持的代码只有很少的常用标签,如果大家发现有转换失败的,请帮我修改代码,估计代码我不会进行修改. 最 ...
- layout_weight使用
layout_weight的真正含义是等比例分割剩余空间, 在线性布局(linearlayout)中对宽度和高度进行比例分割, 三个子linearlayout分割父linearlayout高度,代码如 ...
- [WPF]记一个Win8"缩放级别"设置导致的问题
这是我电脑的分辨率设置: 关键在于设置了缩放级别"较大",即150%的缩放. 接下来在WinForm中用各种方法取得的屏幕分辨率都是缩放之后的,但是这个时候的鼠标事件中鼠标位置也是 ...
- oracle数据同步
随着各行业信息化水平的不断提升,各种各样的信息管理系统都被广泛使用,各系统间数据完全独立,形成了大量的信息孤岛.出于管理及决策方面的需求,实现各平台的数据同步是一个很迫切的需求,TreeSoft数据库 ...