NPOI Excel类
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using NPOI.HSSF.UserModel;
using NPOI.HPSF;
using NPOI.POIFS.FileSystem;
using System.IO;
using NPOI.SS.Util;
namespace ExcelPlay
{
public class Excel
{
public HSSFWorkbook hssfwork; //工作簿
/// <summary>
/// 初始化Excel
/// </summary>
public Excel()
{
hssfwork = new HSSFWorkbook(); //创建工作簿
}
/// <summary>
/// 初始化打开Excel
/// </summary>
/// <param name="path"></param>
public Excel(string path)
{
FileStream file = new FileStream(path, FileMode.Open);
hssfwork = new HSSFWorkbook(file); //创建工作簿
}
/// <summary>
/// 创建工作表
/// </summary>
/// <param name="ShellName"></param>
public NPOI.SS.UserModel.ISheet CreateShell(string ShellName)
{
NPOI.SS.UserModel.ISheet sheet; //工作表
sheet = hssfwork.CreateSheet(ShellName);
return sheet;
}
/// <summary>
/// 写主题公司信息
/// </summary>
/// <param name="Document"></param>
/// <param name="Summary"></param>
public void WriteInfomation(string Document, string Summary)
{
DocumentSummaryInformation dsi = PropertySetFactory.CreateDocumentSummaryInformation(); //创建summaryinformation文件 公司名
dsi.Company = "mo";
SummaryInformation si = PropertySetFactory.CreateSummaryInformation(); //创建summaryinformation 主题
si.Subject = "Example";
hssfwork.DocumentSummaryInformation = dsi; //创建好的传递给工作簿
hssfwork.SummaryInformation = si;
}
/// <summary>
/// 获取工作表
/// </summary>
/// <param name="LstName"></param>
/// <returns></returns>
public List<string> GetSheet(List<string> LstName)
{
for (int i = 0; i < hssfwork.NumberOfSheets; i++)
{
LstName.Add(hssfwork.GetSheetName(i));
}
return LstName;
}
/// <summary>
/// 储存工作簿
/// </summary>
/// <param name ="path"></param>
public void SaveWorkbook(string path)
{
FileStream file = new FileStream(path, FileMode.Create);
hssfwork.Write(file);
file.Close(); // 写入输入流文件
}
/// <summary>
/// 写入数据
/// </summary>
/// <param name ="Row"></param>
/// <param name ="Column"></param>
/// <param name ="data"></param>
/// <param name ="sheet"></param>
public void WriteData(int Row, int Column, string data, NPOI.SS.UserModel.ISheet sheet)
{
sheet.CreateRow(Row).CreateCell(Column).SetCellValue(data);
}
/// <summary>
/// 写入数据
/// </summary>
/// <param name="Row"></param>
/// <param name="Column"></param>
/// <param name="data"></param>
/// <param name="sheet"></param>
public void WriteData(int Row, int Column, double data, NPOI.SS.UserModel.ISheet sheet)
{
sheet.CreateRow(Row).CreateCell(Column).SetCellValue(data);
}
/// <summary>
/// 写入数据
/// </summary>
/// <param name="Row"></param>
/// <param name="Column"></param>
/// <param name="data"></param>
/// <param name="sheet"></param>
public void WriteData(int Row, int Column, bool data, NPOI.SS.UserModel.ISheet sheet)
{
sheet.CreateRow(Row).CreateCell(Column).SetCellValue(data);
}
/// <summary>
/// 写入数据
/// </summary>
/// <param name="Row"></param>
/// <param name="Column"></param>
/// <param name="data"></param>
/// <param name="sheet"></param>
/// <param name="Flag"></param>
public void WriteData(int Row, int Column, DateTime data, NPOI.SS.UserModel.ISheet sheet,string Flag)
{
sheet.CreateRow(Row).CreateCell(Column).SetCellValue(data);
setFormat(Row, Column, Flag, sheet);
}
/// <summary>
/// 写入数据
/// </summary>
/// <param name="Row"></param>
/// <param name="data"></param>
/// <param name="sheet"></param>
public void WriteData(int Row,string[] data,NPOI.SS.UserModel.ISheet sheet)
{
int Column = 0;
foreach (string str in data)
{
if (Column == 0)
{
sheet.CreateRow(Row).CreateCell(Column).SetCellValue(str);
}
else
{
sheet.GetRow(Row).CreateCell(Column).SetCellValue(str);
}
Column++;
}
}
/// <summary>
/// 写入数据
/// </summary>
/// <param name="Row"></param>
/// <param name="data"></param>
/// <param name="sheet"></param>
public void WriteData(int Row, double[] data, NPOI.SS.UserModel.ISheet sheet)
{
int Column = 0;
foreach (double str in data)
{
if (Column == 0)
{
sheet.CreateRow(Row).CreateCell(Column).SetCellValue(str);
}
else
{
sheet.GetRow(Row).CreateCell(Column).SetCellValue(str);
}
Column++;
}
}
/// <summary>
/// 写入数据
/// </summary>
/// <param name="Row"></param>
/// <param name="data"></param>
/// <param name="sheet"></param>
public void WriteData(int Row, bool[] data, NPOI.SS.UserModel.ISheet sheet)
{
int Column = 0;
foreach (bool str in data)
{
if (Column == 0)
{
sheet.CreateRow(Row).CreateCell(Column).SetCellValue(str);
}
else
{
sheet.GetRow(Row).CreateCell(Column).SetCellValue(str);
}
Column++;
}
}
/// <summary>
/// 写入数据
/// </summary>
/// <param name="Row"></param>
/// <param name="data"></param>
/// <param name="sheet"></param>
/// <param name="Flag"></param>
public void WriteData(int Row, DateTime[] data, NPOI.SS.UserModel.ISheet sheet,string Flag)
{
int Column = 0;
foreach (DateTime str in data)
{
if (Column == 0)
{
sheet.CreateRow(Row).CreateCell(Column).SetCellValue(str);
}
else
{
sheet.GetRow(Row).CreateCell(Column).SetCellValue(str);
}
setFormat(Row, Column, Flag, sheet);
Column++;
}
}
/// <summary>
/// 写入数据
/// </summary>
/// <param name="diff"></param>
/// <param name="Column"></param>
/// <param name="data"></param>
/// <param name="sheet"></param>
public void WriteData(bool diff,int Column, string[] data, NPOI.SS.UserModel.ISheet sheet)
{
int Row = 0;
foreach (string str in data)
{
if (diff)
{
sheet.CreateRow(Row).CreateCell(Column).SetCellValue(str);
}
else
{
sheet.GetRow(Row).CreateCell(Column).SetCellValue(str);
}
Row++;
}
}
/// <summary>
/// 写入数据
/// </summary>
/// <param name="diff"></param>
/// <param name="Column"></param>
/// <param name="data"></param>
/// <param name="sheet"></param>
public void WriteData(bool diff,int Column, double[] data, NPOI.SS.UserModel.ISheet sheet)
{
int Row = 0;
foreach (double str in data)
{
if (diff)
{
sheet.CreateRow(Row).CreateCell(Column).SetCellValue(str);
}
else
{
sheet.GetRow(Row).CreateCell(Column).SetCellValue(str);
}
Row++;
}
}
/// <summary>
/// 写入数据
/// </summary>
/// <param name="diff"></param>
/// <param name="Column"></param>
/// <param name="data"></param>
/// <param name="sheet"></param>
public void WriteData(bool diff, int Column, bool[] data, NPOI.SS.UserModel.ISheet sheet)
{
int Row = 0;
foreach (bool str in data)
{
if (diff)
{
sheet.CreateRow(Row).CreateCell(Column).SetCellValue(str);
}
else
{
sheet.GetRow(Row).CreateCell(Column).SetCellValue(str);
}
Row++;
}
}
/// <summary>
/// 写入数据
/// </summary>
/// <param name="diff"></param>
/// <param name="Column"></param>
/// <param name="data"></param>
/// <param name="sheet"></param>
/// <param name="Flag"></param>
public void WriteData(bool diff, int Column, DateTime[] data, NPOI.SS.UserModel.ISheet sheet,string Flag)
{
int Row = 0;
foreach (DateTime str in data)
{
if (diff)
{
sheet.CreateRow(Row).CreateCell(Column).SetCellValue(str);
}
else
{
sheet.GetRow(Row).CreateCell(Column).SetCellValue(str);
}
Row++;
}
}
/// <summary>
/// 写入数据
/// </summary>
/// <param name="Row"></param>
/// <param name="Column"></param>
/// <param name="data"></param>
/// <param name="sheet"></param>
public void WriteData(int Row, int Column, string[,] data, NPOI.SS.UserModel.ISheet sheet)
{
int lengthRow = data.GetLength(0);
int lengthColumn = data.GetLength(1);
for (int n = 0; n < lengthRow; n++)
{
for (int m = 0; m < lengthColumn; m++)
{
if (m == 0)
{
sheet.CreateRow(Row + n).CreateCell(Column + m).SetCellValue(data[n, m]);
}
else
{
sheet.GetRow(Row + n).CreateCell(Column + m).SetCellValue(data[n, m]);
}
}
}
}
/// <summary>
/// 写入数据
/// </summary>
/// <param name="Row"></param>
/// <param name="Column"></param>
/// <param name="data"></param>
/// <param name="sheet"></param>
public void WriteData(int Row, int Column, double[,] data, NPOI.SS.UserModel.ISheet sheet)
{
int lengthRow = data.GetLength(0);
int lengthColumn = data.GetLength(1);
for (int n = 0; n < lengthRow; n++)
{
for (int m = 0; m < lengthColumn; m++)
{
if (m == 0)
{
sheet.CreateRow(Row + n).CreateCell(Column + m).SetCellValue(data[n, m]);
}
else
{
sheet.GetRow(Row + n).CreateCell(Column + m).SetCellValue(data[n, m]);
}
}
}
}
/// <summary>
/// 写入数据
/// </summary>
/// <param name="Row"></param>
/// <param name="Column"></param>
/// <param name="data"></param>
/// <param name="sheet"></param>
public void WriteData(int Row, int Column, bool[,] data, NPOI.SS.UserModel.ISheet sheet)
{
int lengthRow = data.GetLength(0);
int lengthColumn = data.GetLength(1);
for (int n = 0; n < lengthRow; n++)
{
for (int m = 0; m < lengthColumn; m++)
{
if (m == 0)
{
sheet.CreateRow(Row + n).CreateCell(Column + m).SetCellValue(data[n, m]);
}
else
{
sheet.GetRow(Row + n).CreateCell(Column + m).SetCellValue(data[n, m]);
}
}
}
}
/// <summary>
/// 写入数据
/// </summary>
/// <param name="Row"></param>
/// <param name="Column"></param>
/// <param name="data"></param>
/// <param name="sheet"></param>
/// <param name="Flag"></param>
public void WriteData(int Row, int Column, DateTime[,] data, NPOI.SS.UserModel.ISheet sheet,string Flag)
{
int lengthRow = data.GetLength(0);
int lengthColumn = data.GetLength(1);
for (int n = 0; n < lengthRow; n++)
{
for (int m = 0; m < lengthColumn; m++)
{
if (m == 0)
{
sheet.CreateRow(Row + n).CreateCell(Column + m).SetCellValue(data[n, m]);
}
else
{
sheet.GetRow(Row + n).CreateCell(Column + m).SetCellValue(data[n, m]);
}
setFormat(Row, Column, Flag, sheet);
}
}
}
/// <summary>
/// 写入标签
/// </summary>
/// <param name="boll"></param>
/// <param name="Row"></param>
/// <param name="Column"></param>
/// <param name="str"></param>
/// <param name="author"></param>
/// <param name="sheet"></param>
/// <param name="dx1"></param>
/// <param name="dy1"></param>
/// <param name="dx2"></param>
/// <param name="dy2"></param>
/// <param name="row1"></param>
/// <param name="col1"></param>
/// <param name="row2"></param>
/// <param name="col2"></param>
public void WriteComment(bool boll,int Row, int Column, string str, string author, NPOI.SS.UserModel.ISheet sheet, int dx1, int dy1, int dx2, int dy2, int row1, int col1, int row2, int col2)
{
NPOI.SS.UserModel.IDrawing drawing = sheet.CreateDrawingPatriarch();
NPOI.SS.UserModel.IComment comment = drawing.CreateCellComment(new HSSFClientAnchor(dx1,dy1,dx2,dy2,col1,row1,col2,row2));
comment.String = new HSSFRichTextString(str);
comment.Author = author;
if (boll)
{
comment.Visible = true;
}
NPOI.SS.UserModel.ICell cell = sheet.CreateRow(Row).CreateCell(Column);
cell.CellComment = comment;
}
/// <summary>
/// 设置格式
/// </summary>
/// <param name="Row"></param>
/// <param name="Column"></param>
/// <param name="Format"></param>
/// <param name="sheet"></param>
public void setFormat(int Row, int Column, string Format, NPOI.SS.UserModel.ISheet sheet)
{
NPOI.SS.UserModel.ICell cell = sheet.GetRow(Row).GetCell(Column);
NPOI.SS.UserModel.ICellStyle cellStyle = hssfwork.CreateCellStyle();
NPOI.SS.UserModel.IDataFormat format = hssfwork.CreateDataFormat();
cellStyle.DataFormat = format.GetFormat(Format);
cell.CellStyle = cellStyle;
}
/// <summary>
/// 设置格式
/// </summary>
/// <param name="boll"></param>
/// <param name="Row"></param>
/// <param name="Column"></param>
/// <param name="Format"></param>
/// <param name="sheet"></param>
public void setFormat(bool boll, int Row, int Column, string Format, NPOI.SS.UserModel.ISheet sheet)
{
NPOI.SS.UserModel.ICell cell = sheet.GetRow(Row).GetCell(Column);
NPOI.SS.UserModel.ICellStyle cellStyle = hssfwork.CreateCellStyle();
cellStyle.DataFormat = HSSFDataFormat.GetBuiltinFormat(Format); //内嵌写入
cell.CellStyle = cellStyle;
}
/// <summary>
/// 合并区域
/// </summary>
/// <param name="Row"></param>
/// <param name="Column"></param>
/// <param name="sheet"></param>
/// <param name="FirstRow"></param>
/// <param name="FirstColumn"></param>
/// <param name="LastRow"></param>
/// <param name="LastColumn"></param>
public void MargeRegion(int Row,int Column ,NPOI.SS.UserModel.ISheet sheet,int FirstRow,int FirstColumn,int LastRow,int LastColumn)
{
NPOI.SS.UserModel.ICell cell = sheet.CreateRow(Row).CreateCell(Column);
sheet.AddMergedRegion(new CellRangeAddress(FirstRow, LastRow, FirstColumn, LastColumn));
}
public object ReadData(int Row,int Column,NPOI.SS.UserModel.ISheet sheet,int checkd)
{
object data = null;
switch (checkd)
{
case 0:
data = sheet.GetRow(Row).GetCell(Column).StringCellValue;
break;
case 1:
data = sheet.GetRow(Row).GetCell(Column).DateCellValue;
break;
case 2:
data = sheet.GetRow(Row).GetCell(Column).NumericCellValue;
break;
case 3:
data = sheet.GetRow(Row).GetCell(Column).BooleanCellValue;
break;
}
return data;
//short num = sheet.GetRow(2).LastCellNum;
}
public List<List<string>> ReadData(NPOI.SS.UserModel.ISheet sheet)
{
List<string> data = new List<string>();
List<List<string>> listdata = new List<List<string>>();
int Rownum = sheet.PhysicalNumberOfRows;
for (int i = 0; i < Rownum; i++)
{
int Column = sheet.GetRow(i).PhysicalNumberOfCells;
for (int m = 0; m < Column; m++)
{
data.Add(sheet.GetRow(i).GetCell(m).StringCellValue);
}
listdata.Add(data);
data = new List<string>();
}
return listdata;
}
}
}
NPOI Excel类的更多相关文章
- NET npoi帮助类
nuget添加npoi /// <summary> /// npoi帮助类 /// </summary> public static class NpoiHelper { // ...
- NPOI 帮助类
NPOI 帮助类 代码实现了来自于互联网 using System; using System.Data; using System.IO; using System.Text; using NPOI ...
- 转载 NPOI Excel 单元格背景颜色对照表
NPOI Excel 单元格颜色对照表,在引用了 NPOI.dll 后可通过 ICellStyle 接口的 FillForegroundColor 属性实现 Excel 单元格的背景色设置,FillP ...
- NPOI Excel 单元格背景颜色对照表
NPOI Excel 单元格颜色对照表,在引用了 NPOI.dll 后可通过 ICellStyle 接口的 FillForegroundColor 属性实现 Excel 单元格的背景色设置,FillP ...
- 022医疗项目-模块二:药品目录的导入导出-对XSSF导出excel类进行封装
资源全部来源于传智播客. 好的架构师写的程序,就算给刚入门的新手看,新手一看就知道怎么去用.所以我们要对XSSF导出excel类进行封装.这是架构师的工作,但我们也要知道. 我们写一个封装类: 这个类 ...
- <转载>NPOI Excel 单元格背景颜色对照表
我转载地址:http://www.holdcode.com/web/details/117 NPOI Excel 单元格颜色对照表,在引用了 NPOI.dll 后可通过 ICellStyle 接口的 ...
- ASP.NET导出EXCEL类
最新ASP.NET导出EXCEL类 说明:可以导出ASP.NET页面和DATAGRID(WebControl)数据,可以导出表单头 using System;using System.Data;usi ...
- C#利用NPOI导出Excel类(简单版)
代码: using System.Data; using System.IO; using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; namespac ...
- NPOI操作EXCEL 类代码
using System; using System.Collections.Generic; using System.Linq; using System.Text; using NPOI.SS. ...
随机推荐
- 解决“iOS 7 app自动更新,无法在app中向用户展示更新内容”问题
转自cocoachina iOS 7能在后台自动app,这对开发者来说和用户都很方便,但是还是有一些缺点.用户不会知道app本次更新的内容,除非他们上到app的App Store页面去查看.开发者也会 ...
- 【Android】设备标识
Android系统以及设备都有很多的“标识”号,比如常见的IMEI,SerizalNumber,UUID等概念,但是这些都存在一定程度上的不可靠性,到底如何标记一台Android设备? 文章内容多来自 ...
- Linux下U盘变成只读
今天用Ubuntu给同学拷贝数据的时候,突然其中一个文件夹U盘就不能复制和删除了.再windows7下可以删除除修改的那个文件夹之外的数据,但修改的那个文件夹死活删除不掉,只读属性也去不掉.再Ubun ...
- apache.http.MalformedChunkCodingException: Chunked stream ended unexpectedly
产生的原因,应该是服务器返回的数据不是规范的格式 .我使用的xutils的httpUtils来实现网络通信的,关于读取数据是在 StringDownloadHandler类中源代码 inputStre ...
- 爬虫技术 -- 基础学习(三)理解URL和URI的联系与区别
网络爬虫的基本操作是抓取网页.首先要了解下URL~~ 在理解URL之前,先了解下URI,这两个概念我曾经混淆过~@_@|| 什么是URI? Web上每种可用的资源,如:html文档.视频,图片等都由一 ...
- 30个实用的 Photoshop 动作《免费下载》
这篇文章向设计师们分享30个实用的 Photoshop 动作下载.Photoshop 的动作是用集合了许多步的操作的集合,使执行任务自动化,这为设计者在进行图像处理的操作上带来很多方便.同时用户还可以 ...
- 扁平化设计的最新趋势 – 长阴影(Long Shadow)
随着互联网的发展,网页设计变得越来越复杂,如今设计的外观和感觉实现网站功能说使用的开发技术一样重要.互联网的功能远远不只是基本的信息共享,现在人们对网站的期望是远远大于几年前的. 如今,HTML5 & ...
- Java魔法堂:注释和注释模板
一.注释 1. 注释类型 [a]. 单行注释 // 单行注释 String type = "单行注释"; [b]. 多行注释 /* * 多行注释 */ String type ...
- 前端翻译:Activating Browser Modes with Doctype
一.前言 原本备份: http://www.cnblogs.com/fsjohnhuang/p/3830623.html 由于本人英语能力有限,译本内容难免有误,望各位指正! 本译文不含附录部分,请知 ...
- jQuery对Table一个字段排序
最近做一个机票的系统,要对航班信息进行排序,所以整理了一下,把排序的方法写下来. 首先table的结构大概如下 最后显示的样式为 首先在每一个tr上加一个自定义属性:data-sort-field-f ...