NPOI读取Excel表格类
public class NPOIHelper
{
private HSSFWorkbook workbook;
public static IWorkbook LoadFromFile(string filepath)
{
using (FileStream fi = new FileStream(filepath, FileMode.Open, FileAccess.Read))
{
return new HSSFWorkbook(fi);
}
}
public static ISheet CreateSheet(string sheetname, IWorkbook workbook)
{
return workbook.CreateSheet(sheetname);
}
public ISheet WriteToTemplate<T>(IList<T> datalist, string sheetname, int fieldstartrowindex, int fieldstartcolindex, int datastartrowindex)
{
return null;
}
public NPOIHelper(string filetemplatepath)
{
workbook = (HSSFWorkbook)LoadFromFile(filetemplatepath);
}
/// <summary>
/// 将List对象转为SHEET
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="sheetname"></param>
/// <param name="data"></param>
/// <param name="titlerowindex">表头列</param>
/// <param name="datarowindex">表数据列</param>
/// <returns></returns>
public int ConvertTOSheet<T>(string sheetname, IList<T> data, int titlerowindex, int datarowindex)
where T : new()
{
ISheet sheet = workbook.GetSheet(sheetname);
IRow titlerow = sheet.GetRow(titlerowindex);
int rowstartindex = titlerow.FirstCellNum;
int rowlastindex = titlerow.LastCellNum;
IDictionary<int, string> fieldindexdic = new Dictionary<int, string>();
for (int i = rowstartindex; i <= rowlastindex; i++)
{
ICell cell = titlerow.GetCell(i);
if (cell != null)
{
string fieldstr = cell.ToString();
if (!string.IsNullOrEmpty(fieldstr))
{
fieldindexdic.Add(cell.ColumnIndex, fieldstr.ToUpper());
}
}
}
IEnumerable<string> fieldtitle = fieldindexdic.Select(x => x.Value).Distinct();
IDictionary<string, PropertyInfo> pifdic = GetPropertyInfoDic<T>(fieldtitle);
for (int i = 0; i < data.Count; i++)
{
IRow datarow = sheet.CreateRow(datarowindex + i);
foreach (var titlekv in fieldindexdic)
{
object dataobject = pifdic[titlekv.Value].GetValue(data[i], null);
if (dataobject != null)
{
ICell datacell = datarow.CreateCell(titlekv.Key);
datacell.SetCellValue(dataobject.ToString());
}
}
}
return workbook.GetSheetIndex(sheet);
}
public IDictionary<string, PropertyInfo> GetPropertyInfoDic<T>(IEnumerable<string> namelist)
where T : new()
{
IDictionary<string, PropertyInfo> pifdic = new Dictionary<string, PropertyInfo>();
PropertyInfo[] pifs = typeof(T).GetProperties();
IEnumerable<PropertyInfo> filedpifs = pifs.Where(x => namelist.Contains(x.Name.ToUpper()));
foreach (var kv in filedpifs)
{
pifdic.Add(kv.Name.ToUpper(), kv);
}
return pifdic;
}
public void DeleteSheet(string sheetname)
{
int sheetindex = workbook.GetSheetIndex(sheetname);
workbook.RemoveSheetAt(sheetindex);
}
public void Write(Stream sm)
{
workbook.Write(sm);
}
public void DeleteRow(string sheetname, int rowindex)
{
ISheet sheet = workbook.GetSheet(sheetname);
IRow row = sheet.GetRow(rowindex);
sheet.RemoveRow(row);
}
#region add by pcitdbt 2013/11/11
#region 将DataTable的数据读取成MemoryStream
public static MemoryStream RenderToExcel(DataTable dt)
{
MemoryStream ms = new MemoryStream();
using (dt)
{
//创建Workbook
HSSFWorkbook book = new HSSFWorkbook();
ISheet sheet = book.CreateSheet(dt.TableName);
//创建一个日期类型的格式
ICellStyle dataStyle = book.CreateCellStyle();
IDataFormat dataFormat = book.CreateDataFormat();
dataStyle.DataFormat = dataFormat.GetFormat("yyyy-mm-dd");
//创建表头
IRow row = sheet.CreateRow(0);
foreach (DataColumn col in dt.Columns)
{
//给表头添加字段名字
row.CreateCell(col.Ordinal).SetCellValue(col.Caption);//Caption没有值则获取ColumnName
//设置列宽
sheet.SetColumnWidth(col.Ordinal, 30 * 110);
}
//创建数据行并添加值
int rowIndex = 1;//标记数据行的位置
foreach (DataRow dr in dt.Rows)
{
IRow dataRow = sheet.CreateRow(rowIndex);
//通过列来获取值
foreach (DataColumn column in dt.Columns)
{
//判断是否是DataTime类型
ICell newCell = dataRow.CreateCell(column.Ordinal);
string drValue = dr[column].ToString();
switch (column.DataType.ToString())
{
case "System.String"://字符串类型
newCell.SetCellValue(drValue);
break;
case "System.DateTime"://日期类型
DateTime dateV;
DateTime.TryParse(drValue, out dateV);
//newCell.SetCellValue(dateV);
newCell.SetCellValue(drValue);
newCell.CellStyle = dataStyle;//格式化显示
break;
case "System.Boolean"://布尔型
bool boolV = false;
bool.TryParse(drValue, out boolV);
newCell.SetCellValue(boolV);
break;
case "System.Int16"://整型
case "System.Int32":
case "System.Int64":
case "System.Byte":
int intV = 0;
int.TryParse(drValue, out intV);
newCell.SetCellValue(intV);
break;
case "System.Decimal"://浮点型
case "System.Double":
double doubV = 0;
double.TryParse(drValue, out doubV);
newCell.SetCellValue(doubV);
break;
case "System.DBNull"://空值处理
newCell.SetCellValue("");
break;
default:
newCell.SetCellValue("");
break;
}
}
//循环一行后i的值自增1
rowIndex++;
}
book.Write(ms);
ms.Flush();
ms.Position = 0;//指定内存流的当前位置
}
return ms;
}
#endregion
#region 将DataReader的数据转换成MemoryStream并返回
public static MemoryStream RenderToExcel(IDataReader dataReader)
{
MemoryStream ms = new MemoryStream();
using (dataReader)
{
HSSFWorkbook book = new HSSFWorkbook();
ISheet sheet = book.CreateSheet("数据表1");
//创建表头
IRow row = sheet.CreateRow(0);
//列的数目
int columnCount = dataReader.FieldCount;
for (int i = 0; i < columnCount; i++)
{
row.CreateCell(i).SetCellValue(dataReader.GetName(i));
}
//创建数据行
int rowIndex = 1;
while (dataReader.Read())//dataReader只能一行一行地读取数据
{
IRow dataRow = sheet.CreateRow(rowIndex);
for (int i = 0; i < columnCount; i++)
{
dataRow.CreateCell(i).SetCellValue(dataReader[i].ToString());
}
rowIndex++;
}
book.Write(ms);
ms.Flush();
ms.Position = 0;
}
return ms;
}
#endregion
#region 将流输出到指定的位置
//保存输出到文件
public static void SaveToFile(MemoryStream ms, string fileName)
{
using (FileStream fs = new FileStream(fileName, FileMode.Create, FileAccess.Write))
{
byte[] data = ms.ToArray();
fs.Write(data, 0, data.Length);
fs.Flush();
data = null;
}
}
#endregion
#region 保存输出到浏览器
public static void SaveToBrowser(MemoryStream ms, System.Web.HttpContext context, string fileName)
{
// 设置编码和附件格式
context.Response.ContentType = "application/vnd.ms-excel";
context.Response.ContentEncoding = Encoding.UTF8;
context.Response.Charset = "";
context.Response.AppendHeader("Content-Disposition",
"attachment;filename=" +System.Web.HttpUtility.UrlEncode(fileName, Encoding.UTF8));
//添加请求报文头
//context.Response.AddHeader("Content-Disposition", "attachment;fileName=" + fileName);
context.Response.BinaryWrite(ms.ToArray());
context.Response.End();
}
#endregion
#region NPOI读取Excel流的数据相关
public DataTable ReadFromExcel(Stream excelStream)
{
DataTable dt = new DataTable();
using (excelStream)
{
//创建WorkBook
HSSFWorkbook book = new HSSFWorkbook(excelStream);
ISheet sheet = book.GetSheetAt(0);//获取第一个表
//获取第一行表头
IRow headRow = sheet.GetRow(0);
//列数
int columnCount = headRow.LastCellNum;//LastCellNum=PhysicalNumberOfCells
int rowCount = sheet.LastRowNum;//LastRowNum=PhysicalNumberOfCellsRow-1
//创建DataTable的表头
for (int i = headRow.FirstCellNum; i < columnCount; i++)
{
DataColumn dc = new DataColumn(headRow.GetCell(i).StringCellValue.ToString());
dt.Columns.Add(dc);
}
//创建数据
for (int i = (sheet.FirstRowNum + 1); i <= rowCount; i++)
{
//一行一行地创建
DataRow dr = dt.NewRow();
IRow dataRow = sheet.GetRow(i);
if (dataRow != null)
{
for (int j = headRow.FirstCellNum; j < columnCount; j++)
{
string cellValue = dataRow.GetCell(j).StringCellValue.ToString();
if (cellValue != "" || cellValue != null)
{
dr[j] = dataRow.GetCell(j).StringCellValue.ToString();
}
}
dt.Rows.Add(dr);
}
}
}
return dt;
}
public static int RenderToDb(Stream excelFileStream, string insertSql)
{
int rowAffected = 0;
using (excelFileStream)
{
HSSFWorkbook workbook = new HSSFWorkbook(excelFileStream);
ISheet sheet = workbook.GetSheetAt(0);//取第一个工作表
StringBuilder builder = new StringBuilder();
IRow headerRow = sheet.GetRow(0);//第一行为标题行
int cellCount = headerRow.LastCellNum;//LastCellNum = PhysicalNumberOfCells
int rowCount = sheet.LastRowNum;//LastRowNum = PhysicalNumberOfRows - 1
for (int i = (sheet.FirstRowNum + 1); i <= rowCount; i++)
{
IRow row = sheet.GetRow(i);
if (row != null)
{
builder.Append(insertSql);
builder.Append(" values (");
for (int j = row.FirstCellNum; j < cellCount; j++)
{
builder.AppendFormat("'{0}',", row.GetCell(j).StringCellValue.Replace("'", "''"));
}
builder.Length = builder.Length - 1;
builder.Append(");");
}
if ((i % 50 == 0 || i == rowCount) && builder.Length > 0)
{
//每50条记录一次批量插入到数据库
//rowAffected += dbAction(builder.ToString());
builder.Length = 0;
}
}
}
return rowAffected;
}
public static bool HasData(Stream excelFileStream)
{
using (excelFileStream)
{
HSSFWorkbook workbook = new HSSFWorkbook(excelFileStream);
if (workbook.NumberOfSheets > 0)
{
ISheet sheet = workbook.GetSheetAt(0);
return sheet.PhysicalNumberOfRows > 0;
}
}
return false;
}
#endregion
#endregion
}
NPOI读取Excel表格类的更多相关文章
- 使用NPOI读取Excel表格内容并进行修改
前言 网上使用NPOI读取Excel文件的例子现在也不少,本文就是参考网上大神们的例子进行修改以适应自己需求的. 参考博文 http://www.cnblogs.com/restran/p/38894 ...
- NPOI读取Excel帮助类,支持xls与xlsx,实现公式解析,空行的处理
NPOI读取Excel(2003或者2010)返回DataTable.支持公式解析,空行处理. /// <summary>读取excel /// 默认第一行为表头 /// </sum ...
- 【第二篇】.NET用NPOI读取Excel表格并在页面预览
博主用的是npoi2.0.1,支持.xls也支持.xlsx 直接上代码吧. <table class="table table-bordered table-striped" ...
- .NET Core 使用NPOI读取Excel返回泛型List集合
我是一名 ASP.NET 程序员,专注于 B/S 项目开发.累计文章阅读量超过一千万,我的博客主页地址:https://www.itsvse.com/blog_xzz.html 网上有很多关于npoi ...
- C# 读取Excel表格内容,以及NPOI的使用
在实际的开发中,我们可能需要读写word或者Excel的内容,在我开发的项目中,需要读取Excel的内容,并将相对应的内容存储到数据库中,这里简单跟大家分享一下,希望能够帮助一些人. 我相信在读写wo ...
- 使用NPOI读取Excel数据到DataTable
如今XML文件的存储格式大行其道,可是也不是适用于全部情况,非常多单位的数据交换还是使用Excel的形式.这就使得我们须要读取Excel内的数据.载入到程序中进行处理.可是如何有效率的读取,如何使程序 ...
- Java读取excel表格
Java读取excel表格 一般都是用poi技术去读取excel表格的,但是这个技术又是什么呢 什么是Apache POI? Apache POI是一种流行的API,它允许程序员使用Java程序创建, ...
- poi读取excel工具类
package com.manage.utils; import ch.qos.logback.core.net.SyslogOutputStream; import com.google.gson. ...
- NPOI读取Excel遇到的坑
NPOI是POI的.NET版本.POI是用Java写成的库,能帮助用户在没有安装Office环境下读取Office2003-2007文件.NPOI在.NET环境下使用,能读写Excel/Word文件. ...
随机推荐
- Scala List的排序函数sortWith
//原始方法: //val list=List("abc","bcd","cde") scala> list.sortWith( (s ...
- Unity3D之游戏暂停制作方法记录
在游戏开发中我们一般都需要涉及到一个功能:游戏暂停,但是这里指的暂停仅仅是核心模块的暂停,并不是整个游戏都暂停,比如一些UI和UI上的动画与特效是不能被暂停的,整个游戏都暂停了玩家该如何继续游戏呢. ...
- Castle IOC容器快速入门
主要内容 1.为什么要IOC 2.什么是Castle IOC容器 3.快速入门示例 4.几个重要的概念 一,为什么要IOC IOC(控制反转或者叫依赖注入)Martin Fowler大师在他的文章中已 ...
- Oracle-11g-R2(11.2.0.3.x)RAC Oracle Grid & Database 零宕机方式回滚 PSU(自动模式)
回滚环境: 1.源库版本: Grid Infrastructure:11.2.0.3.15 Database:11.2.0.3.15 2.目标库版本: Grid Infrastructure:11.2 ...
- php 常用设计模式详解
1.单例模式 构造函数必须为private 一个保存类实例静态成员变量 拥有一个访问这个实例的公共静态方法(常用getInstance()方法进行实例化单例类,通过instanceof操作符可以检测到 ...
- [置顶] 问题解决——XP线程池找不到QueueUserWorkItem
2013年7月11号 主管让同事写一个并发100的小工具进行什么压力测试,据说是创建100个线程. 我表示这真真的是在坑人! 线程创建消耗资源,以自己的笔记本来跑这个东西,时间片都消耗在了线程切换上了 ...
- cocos2d-x CCArray
转自:http://blog.csdn.net/onerain88/article/details/8164210 1. CCArray只是提供了一个面向对象的封装类 其继承于CCObject类(CC ...
- Win7 不能安装 msi 解决办法
Win7 不能安装Setup.msi解决办法 解决方案如下: 新建一个文本文件,输入msiexec /i d:\Setup.msi (假设文件名为Setup.msi ,放在d盘根目录下,即是安装程序的 ...
- MYSQL之HANDLER_READ_*详细讲解
http://www.databaseclub.com/category/performance/
- Metadata Lock原理6
一 简介 上一篇文章 <MetaData Lock 之一> 简单的介绍了MySQL 引入MDL 的前因后果,本文深入了解MDL的实现原理和运行机制.二 MDL 的类型 meta ...