ExcelHelper
NPOI下载:http://pan.baidu.com/s/1JNAGm
最新封装类:
2016-03-14
1.添加对OleConn的读
private static string connstring = @"Provider=Microsoft.Jet.OLEDB.4.0;Persist Security Info=False;Data Source=" + path + ";Extended Properties=Excel 8.0";
public static DataTable ExecelTable(string sql, params OleDbParameter[] parameter)
{
using (OleDbConnection conn = new OleDbConnection(connstring))
{
conn.Open();
using (OleDbCommand comm = new OleDbCommand(sql, conn))
{
if (parameter != null) comm.Parameters.AddRange(parameter);
if (conn.State == ConnectionState.Closed) conn.Open();
DataTable dt = new DataTable();
OleDbDataAdapter oda = new OleDbDataAdapter(comm);
oda.Fill(dt);
return dt;
}
}
}
2016-04-16
sheet到datatable时候,表中一行是列名
using NPOI.HSSF.UserModel;
using NPOI.SS.UserModel;
using System;
using System.Collections.Generic;
using System.Data;
using System.IO;
using System.Reflection;
using System.Web; namespace ssm.Helper
{
public class ExcelHelper
{
#region 导入excel /// <summary>
/// 读取excel路径 生成 DataSet
/// </summary>
/// <param name="path"></param>
public static DataSet GetExcelToDs(string path)
{
DataSet ds = new DataSet();
using (FileStream fs = File.OpenRead(path))
{
using (Workbook wb = new HSSFWorkbook(fs))
{
for (int i = ; i < wb.NumberOfSheets; i++)
{
DataTable dt = ds.Tables[i];
using (Sheet s = wb.CreateSheet())
{
int RowLen = s.LastRowNum;
for (int j = ; j < RowLen; j++)
{
DataRow dr = dt.NewRow();
Row r = s.GetRow(j);
int ColLen = r.LastCellNum;
for (int k = ; k < ColLen; k++)
{
dr[k] = r.GetCell(k);
}
}
}
}
}
}
return ds;
}
public static DataTable GetExcelToDt(string path)
{
DataTable dt = new DataTable();
using (FileStream fs = File.OpenRead(path))
{
using (Workbook wb = new HSSFWorkbook(fs))
{
using (Sheet s = wb.GetSheetAt())
{
Row HeadRow = s.GetRow();
for (int t = ; t < HeadRow.LastCellNum; t++) //set DataTable columns name
{
dt.Columns.Add(HeadRow.GetCell(t).ToString());
} int RowLen = s.LastRowNum;
int ColLen = HeadRow.LastCellNum;
for (int j = ; j < RowLen; j++) // TO DataTable
{
int sheetNum = j + ;
DataRow dr = dt.NewRow();
Row r = s.GetRow(sheetNum); for (int k = ; k < ColLen; k++)
{
// int sheetNum = k + 1; if(r.GetCell(k) != null)
dr[k] = r.GetCell(k); }
dt.Rows.Add(dr);
}
}
}
}
return dt;
}
public static DataTable GetExcelToDt(FileStream fs)
{
DataTable dt = new DataTable();
using (Workbook wb = new HSSFWorkbook(fs))
{
using (Sheet s = wb.GetSheetAt())
{
Row HeadRow = s.GetRow();
for (int t = ; t < HeadRow.LastCellNum; t++) //set DataTable columns name
{
dt.Columns.Add(HeadRow.GetCell(t).ToString());
} int RowLen = s.LastRowNum;
for (int j = ; j < RowLen; j++) // TO DataTable
{
DataRow dr = dt.NewRow();
Row r = s.GetRow(j);
int ColLen = r.LastCellNum;
for (int k = ; k < ColLen; k++)
{
dr[k] = r.GetCell(k);
}
dt.Rows.Add(dr);
}
}
}
return dt;
}
#endregion #region 导出excel
/// <summary>
/// 表转化成excel并且下载
/// </summary>
/// <param name="dt">表</param>
/// <param name="title">文件名</param>
public static void CreateExcelToDown(DataTable dt, string title)
{
using (Workbook book = new HSSFWorkbook())
{
Sheet sheet = book.CreateSheet("sheet1"); Row headerrow = sheet.CreateRow();
CellStyle style = book.CreateCellStyle();
style.Alignment = HorizontalAlignment.CENTER;
//1.转化表头
for (int i = ; i < dt.Columns.Count; i++)
{
Cell cell = headerrow.CreateCell(i);
cell.CellStyle = style;
cell.SetCellValue(dt.Columns[i].ColumnName);
}
//2.填写数据
int RowLen = dt.Rows.Count;
int ColLen = dt.Columns.Count;
for (int i = ; i < RowLen; i++)
{
DataRow dr = dt.Rows[i];
Row r = sheet.CreateRow((i+));
for (int j = ; j < ColLen; j++)
{
r.CreateCell(j).SetCellValue(dr[j].ToString());
}
}
//3.下载
using (MemoryStream ms = new MemoryStream())
{
book.Write(ms);
HttpContext.Current.Response.AddHeader("Content-Disposition", string.Format("attachment; filename={0}.xls", HttpUtility.UrlEncode(title + "_" + DateTime.Now.ToString("yyyy-MM-dd"), System.Text.Encoding.UTF8)));
HttpContext.Current.Response.BinaryWrite(ms.ToArray());
HttpContext.Current.Response.End();
}
}
}
public static void CreateExcelToDown<T>(List<T> lt , string title)
{
Type type = lt.GetType();
PropertyInfo[] pi = type.GetProperties(); using (Workbook book = new HSSFWorkbook())
{
Sheet sheet = book.CreateSheet("sheet1"); Row headerrow = sheet.CreateRow();
CellStyle style = book.CreateCellStyle();
style.Alignment = HorizontalAlignment.CENTER; //1.转化表头
for (int i = ; i < pi.Length; i++)
{
Cell cell = headerrow.CreateCell(i);
cell.CellStyle = style;
cell.SetCellValue(pi[i].Name);
}
//2.填写数据
int RowLen = lt.Count; // get List<> count
int ColLen = pi.Length; // get proper length //3.下载
using (MemoryStream ms = new MemoryStream())
{
book.Write(ms);
HttpContext.Current.Response.AddHeader("Content-Disposition", string.Format("attachment; filename={0}.xls", HttpUtility.UrlEncode(title + "_" + DateTime.Now.ToString("yyyy-MM-dd"), System.Text.Encoding.UTF8)));
HttpContext.Current.Response.BinaryWrite(ms.ToArray());
HttpContext.Current.Response.End();
}
}
}
/// <summary>
/// DataSet 创建生成 excel文件,保存到本地
/// </summary>
/// <param name="name"></param>
/// <param name="ds"></param>
public static bool CreateExcelToFile(string name, DataSet ds)
{
bool isValue = false;
int DsLen = ds.Tables.Count;
using (Workbook wk = new HSSFWorkbook())
{
foreach (DataTable dt in ds.Tables)
{
using (Sheet s = wk.CreateSheet())
{
int RowLen = dt.Rows.Count;
int ColLen = dt.Columns.Count;
for (int i = ; i < RowLen; i++)
{
DataRow dr = dt.Rows[i];
Row r = s.CreateRow(i);
for (int j = ; j < ColLen; j++)
{
r.CreateCell(j).SetCellValue(dr[j].ToString());
}
}
using (FileStream fs = File.OpenWrite(System.Web.HttpContext.Current.Server.MapPath(name + @".xls")))
{
wk.Write(fs);
}
}
}
isValue = true;
}
return isValue;
} /// <summary>
/// DataTable创建生成Excel,保存到本地
/// </summary>
/// <param name="name"></param>
/// <param name="dt"></param>
/// <returns></returns>
public static bool CreateExcelToFile(string name, DataTable dt)
{
bool isValue = false;
using (Workbook wk = new HSSFWorkbook())
{
using (Sheet s = wk.CreateSheet())
{
int RowLen = dt.Rows.Count;
int ColLen = dt.Columns.Count;
for (int i = ; i < RowLen; i++)
{
DataRow dr = dt.Rows[i];
Row r = s.CreateRow(i);
for (int j = ; j < ColLen; j++)
{
r.CreateCell(j).SetCellValue(dr[j].ToString());
}
}
using (FileStream fs = File.OpenWrite(System.Web.HttpContext.Current.Server.MapPath(name + @".xls")))
{
wk.Write(fs);
}
}
isValue = true;
}
return isValue;
} /// <summary>
///error DataTable 创建生成 Excel ,生成文件流
/// </summary>
/// <param name="dt"></param>
/// <returns></returns>
public static MemoryStream CreateExcelToStream(DataTable dt)
{
using (Workbook wk = new HSSFWorkbook())
{
using (Sheet s = wk.CreateSheet())
{
int RowLen = dt.Rows.Count;
int ColLen = dt.Columns.Count;
for (int i = ; i < RowLen; i++)
{
DataRow dr = dt.Rows[i];
Row r = s.CreateRow(i);
for (int j = ; j < ColLen; j++)
{
r.CreateCell(j).SetCellValue(dr[j].ToString());
}
}
MemoryStream ms = new MemoryStream();
wk.Write(ms);
return ms;
}
}
}
#endregion } }
2016-05-11
修改4.16问题:表中一行是列名
public class ExcelHelper
{
#region 导入excel /// <summary>
/// 读取excel路径 生成 DataSet
/// </summary>
/// <param name="path"></param>
public static DataSet GetExcelToDs(string path)
{
DataSet ds = new DataSet();
using (FileStream fs = File.OpenRead(path))
{
using (Workbook wb = new HSSFWorkbook(fs))
{
for (int i = ; i < wb.NumberOfSheets; i++)
{
DataTable dt = ds.Tables[i];
using (Sheet s = wb.CreateSheet())
{
int RowLen = s.LastRowNum;
for (int j = ; j < RowLen; j++)
{
DataRow dr = dt.NewRow();
Row r = s.GetRow(j);
int ColLen = r.LastCellNum;
for (int k = ; k < ColLen; k++)
{
dr[k] = r.GetCell(k);
}
}
}
}
}
}
return ds;
}
public static DataTable GetExcelToDt(string path)
{
DataTable dt = new DataTable();
using (FileStream fs = File.OpenRead(path))
{
using (Workbook wb = new HSSFWorkbook(fs))
{
using (Sheet s = wb.GetSheetAt())
{
Row HeadRow = s.GetRow();
for (int t = ; t < HeadRow.LastCellNum; t++) //set DataTable columns name
{
dt.Columns.Add(HeadRow.GetCell(t).ToString());
} int RowLen = s.LastRowNum;
int ColLen = HeadRow.LastCellNum;
for (int j = ; j < RowLen; j++) // TO DataTable
{
int sheetNum = j + ;
DataRow dr = dt.NewRow();
Row r = s.GetRow(sheetNum); for (int k = ; k < ColLen; k++)
{
// int sheetNum = k + 1; if(r.GetCell(k) != null)
dr[k] = r.GetCell(k); }
dt.Rows.Add(dr);
}
}
}
}
return dt;
}
public static DataTable GetExcelToDt(FileStream fs)
{
DataTable dt = new DataTable();
using (Workbook wb = new HSSFWorkbook(fs))
{
using (Sheet s = wb.GetSheetAt())
{
Row HeadRow = s.GetRow();
for (int t = ; t < HeadRow.LastCellNum; t++) //set DataTable columns name
{
dt.Columns.Add(HeadRow.GetCell(t).ToString());
} int RowLen = s.LastRowNum;
for (int j = ; j < RowLen; j++) // TO DataTable
{
DataRow dr = dt.NewRow();
Row r = s.GetRow(j);
int ColLen = r.LastCellNum;
for (int k = ; k < ColLen; k++)
{
dr[k] = r.GetCell(k);
}
dt.Rows.Add(dr);
}
}
}
return dt;
}
#endregion #region 导出excel
/// <summary>
/// 表转化成excel并且下载
/// </summary>
/// <param name="dt">表</param>
/// <param name="title">文件名</param>
public static void CreateExcelToDown(DataTable dt, string title)
{
using (Workbook book = new HSSFWorkbook())
{
Sheet sheet = book.CreateSheet("sheet1"); Row headerrow = sheet.CreateRow();
CellStyle style = book.CreateCellStyle();
style.Alignment = HorizontalAlignment.CENTER;
//1.转化表头
for (int i = ; i < dt.Columns.Count; i++)
{
Cell cell = headerrow.CreateCell(i);
cell.CellStyle = style;
cell.SetCellValue(dt.Columns[i].ColumnName);
}
//2.填写数据
int RowLen = dt.Rows.Count;
int ColLen = dt.Columns.Count;
for (int i = ; i < RowLen; i++)
{
DataRow dr = dt.Rows[i];
Row r = sheet.CreateRow((i+));
for (int j = ; j < ColLen; j++)
{
r.CreateCell(j).SetCellValue(dr[j].ToString());
}
}
//3.下载
using (MemoryStream ms = new MemoryStream())
{
book.Write(ms);
HttpContext.Current.Response.AddHeader("Content-Disposition", string.Format("attachment; filename={0}.xls", HttpUtility.UrlEncode(title + "_" + DateTime.Now.ToString("yyyy-MM-dd"), System.Text.Encoding.UTF8)));
HttpContext.Current.Response.BinaryWrite(ms.ToArray());
HttpContext.Current.Response.End();
}
}
}
public static void CreateExcelToDown<T>(List<T> lt , string title)
{
Type type = lt.GetType();
PropertyInfo[] pi = type.GetProperties(); using (Workbook book = new HSSFWorkbook())
{
Sheet sheet = book.CreateSheet("sheet1"); Row headerrow = sheet.CreateRow();
CellStyle style = book.CreateCellStyle();
style.Alignment = HorizontalAlignment.CENTER; //1.转化表头
for (int i = ; i < pi.Length; i++)
{
Cell cell = headerrow.CreateCell(i);
cell.CellStyle = style;
cell.SetCellValue(pi[i].Name);
}
//2.填写数据
int RowLen = lt.Count; // get List<> count
int ColLen = pi.Length; // get proper length //3.下载
using (MemoryStream ms = new MemoryStream())
{
book.Write(ms);
HttpContext.Current.Response.AddHeader("Content-Disposition", string.Format("attachment; filename={0}.xls", HttpUtility.UrlEncode(title + "_" + DateTime.Now.ToString("yyyy-MM-dd"), System.Text.Encoding.UTF8)));
HttpContext.Current.Response.BinaryWrite(ms.ToArray());
HttpContext.Current.Response.End();
}
}
}
/// <summary>
/// DataSet 创建生成 excel文件,保存到本地
/// </summary>
/// <param name="name"></param>
/// <param name="ds"></param>
public static bool CreateExcelToFile(string name, DataSet ds)
{
bool isValue = false;
int DsLen = ds.Tables.Count;
using (Workbook wk = new HSSFWorkbook())
{
foreach (DataTable dt in ds.Tables)
{
using (Sheet s = wk.CreateSheet())
{
int RowLen = dt.Rows.Count;
int ColLen = dt.Columns.Count;
for (int i = ; i < RowLen; i++)
{
DataRow dr = dt.Rows[i];
Row r = s.CreateRow(i);
for (int j = ; j < ColLen; j++)
{
r.CreateCell(j).SetCellValue(dr[j].ToString());
}
}
using (FileStream fs = File.OpenWrite(System.Web.HttpContext.Current.Server.MapPath(name + @".xls")))
{
wk.Write(fs);
}
}
}
isValue = true;
}
return isValue;
} /// <summary>
/// DataTable创建生成Excel,保存到本地
/// </summary>
/// <param name="name"></param>
/// <param name="dt"></param>
/// <returns></returns>
public static bool CreateExcelToFile(string name, DataTable dt)
{
bool isValue = false;
using (Workbook wk = new HSSFWorkbook())
{
using (Sheet s = wk.CreateSheet())
{
int RowLen = dt.Rows.Count;
int ColLen = dt.Columns.Count;
for (int i = ; i < RowLen; i++)
{
DataRow dr = dt.Rows[i];
Row r = s.CreateRow(i);
for (int j = ; j < ColLen; j++)
{
r.CreateCell(j).SetCellValue(dr[j].ToString());
}
}
using (FileStream fs = File.OpenWrite(System.Web.HttpContext.Current.Server.MapPath(name + @".xls")))
{
wk.Write(fs);
}
}
isValue = true;
}
return isValue;
} /// <summary>
///error DataTable 创建生成 Excel ,生成文件流
/// </summary>
/// <param name="dt"></param>
/// <returns></returns>
public static MemoryStream CreateExcelToStream(DataTable dt)
{
using (Workbook wk = new HSSFWorkbook())
{
using (Sheet s = wk.CreateSheet())
{
int RowLen = dt.Rows.Count;
int ColLen = dt.Columns.Count;
for (int i = ; i < RowLen; i++)
{
DataRow dr = dt.Rows[i];
Row r = s.CreateRow(i);
for (int j = ; j < ColLen; j++)
{
r.CreateCell(j).SetCellValue(dr[j].ToString());
}
}
MemoryStream ms = new MemoryStream();
wk.Write(ms);
return ms;
}
}
}
#endregion }
2016.5.11
增加一个按模型类导出EXCEL的方法:
public string CreateExcelDown<T>(string Title, List<T> lt)
{
//用来分行色的
string color = "";
int num = ; StringBuilder sb = new StringBuilder();
Type type = typeof(T);
PropertyInfo[] pi = type.GetProperties(); //生成表头
sb.Append(@"<table style=""width:900px;"" cellpadding=""2"" cellspacing=""0"" align=""center"" border=""1"" bordercolor=""#000000"">");
sb.Append("<tbody> <tr>"); sb.Append(@" <td colspan=""" + pi.Count() + @""" style=""text-align:center;""><h2>");
sb.Append(Title);
sb.Append("</h2></td>");
sb.Append("</tr>"); //生成列名
sb.Append("<tr>");
foreach (var p in pi)
{
sb.Append(@"<td style=""text-align:center;""><h4>" + p.Name + "</h4></td>");
}
sb.Append("</tr>"); //输入内容
foreach (var m in lt)
{
if ((num++) % == )
color = "background-color:#FFE500";
else
color = "";
sb.Append("<tr>");
foreach (var i in pi)
{
sb.AppendFormat(@"<td style=""text-align:center;{0}"">{1}</td>", color, i.GetValue(m, null));
}
sb.Append("</tr>");
} sb.Append("</tbody></table>"); return sb.ToString();
}
public string CreateExcelDown<T>(string Title, List<T> lt)
Title 表名,List<T> lt:你要用到的List集合
上面只是生成HTML,如果要下载还需要实习以下代码(MVC中):
public FileResult DownBmxx(bmmanVm s)
{
//1.获取信息表
List<bmmanVm> si = zsglBLL.GetBmMan(MyCookie.Read()); //2.剔除不要信息,只是给你做
if (s.DateTime != )
si = si.Where(x => x.DateTime == s.DateTime).ToList();
if (s.RecommName != null)
si = si.Where(x => x.RecommName == s.RecommName).ToList();
if (s.Card != null)
si = si.Where(x => x.Card.Contains(s.Card)).ToList();
if (s.Name != null)
si = si.Where(x => x.Name.Contains(s.Name)).ToList();
if (s.MajorName != null)
si = si.Where(x => x.MajorName.Contains(s.MajorName)).ToList();
if (s.SchoolName != null)
si = si.Where(x => x.SchoolName.Contains(s.SchoolName)).ToList(); //3.生成excel模型表
int i = ;
List<outBmxxExcelVm> lo = si.Select(x
=> new outBmxxExcelVm {
专业名=x.MajorName,
入学时间=x.DateTime,
姓名=x.Name,
学校名=x.SchoolName,
层次=x.lv,
类型=x.fm,
编号=i++,
负责人=x.RecommName
})
.ToList(); //4.生成下载流
string html = CreateExcelDown("招生信息表", lo);
byte[] fileContents = Encoding.Default.GetBytes(html); //5.文件流下载
return File(fileContents, "application/ms-excel", "招生信息表.xls");
ExcelHelper的更多相关文章
- C#EXCEL 操作类--C#ExcelHelper操作类
主要功能如下1.导出Excel文件,自动返回可下载的文件流 2.导出Excel文件,转换为可读模式3.导出Excel文件,并自定义文件名4.将数据导出至Excel文件5.将指定的集合数据导出至Exce ...
- 我写的一个ExcelHelper通用类,可用于读取或生成数据
读取或生成EXCEL数据的方法有很多,一般常见的有: 1.通过OFFICE EXCEL组件,优点:读取与生成EXCEL文件方便,缺点:服务器上必须安装OFFICE软件,且进程无法及时释放 2.通过第三 ...
- Excel导入数据(97--2003版本)的ExcelHelper
首先确定excel的版本为97~2003版本 其次创建一个帮助类——ExcelHelper //单个sheet public static DataTable AnalysisExcel(string ...
- 【转】ExcelHelper类,用npoi读取Excel文档
//------------------------------------------------------------------------------------- // All Right ...
- [Excel] C# ExcelHelper操作类 (转载)
点击下载 ExcelHelper.rar 主要功能如下1.导出Excel文件,自动返回可下载的文件流 2.导出Excel文件,转换为可读模式3.导出Excel文件,并自定义文件名4.将数据导出至Exc ...
- 基于NPOI开源框架写的ExcelHelper【转载】
namespace ExcelTest { using System; using System.Collections.Generic; using System.Data; using Syste ...
- ExcelHelper Excel,Export,Import
using System; using System.Collections.Generic; using System.Data; using System.Data.Odbc; using Sys ...
- C# ExcelHelper
using System; using System.IO; using System.Data; using System.Collections; using System.Data.OleDb; ...
- x01.ExcelHelper: NPOI 操作
Excel 操作,具有十分明显的针对性,故很难通用,但这并不妨碍参考后以解决自己的实际问题. 有一汇总表如下: 当然,只是示范,产品的代码应该唯一!现在要根据此汇总表产生各个客户的产品清单.由于客户较 ...
随机推荐
- ReCap 360 photo照片建模技术的又一个例子
这是我做的又一个利用Autodesk ReCap 360 照片建模技术做的一个例子.你可以下载模型自己把玩,或者下载原始照片自己试一试. 拍摄工具: 小米手机 照片数量:约120张 后期处理工具: p ...
- JavaScript学习09 函数本质及Function对象深入探索
JavaScript学习09 函数本质及Function对象深入探索 在JavaScript中,函数function就是对象. JS中没有方法重载 在JavaScript中,没有方法(函数)重载的概念 ...
- UIApplicationDelegate
App受到干扰时,UIApplication会通知它的delegate对象,让delegate处理系统事件. 项目中的AppDelegate已经遵守了UIApplicationDelegate协议 ...
- 软工_Alpha阶段事后分析总计
1.设想和目标 1.1 我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? 我们的软件主要解决狼人杀玩家在游戏时的一些痛点.因为之前自己对于游戏中那些不方便的地方有过体 ...
- 开源游戏 “Elvish Bird”
简介: 这个游戏是我在今年(2014/03)课余时闲着无聊做的一个冒险类小游戏,总共花了5个工作日才完成,为了游戏的效率,做了很多优化,目前在IE8以上浏览器能够流畅运行,运行时如果屏幕分辨率不兼容, ...
- mysql源码解读之事务提交过程(一)
mysql是一种关系型数据库,关系型数据库一个重要的特性就是支持事务,这是区别于no-sql产品的一个核心特性.当然了,no-sql产品支持键值查询,不能支持sql语句,这也是一个区别.今天主要讨论下 ...
- 挖一挖C#中那些我们不常用的东西之系列(5)——FlagAttribute
说到FlagsAttribute,源自前几天看到了一小段代码,大概意思就是根据航班政策来返回哪些配送方式是否可用,根据这些是否可用 来隐藏或者开启界面的相关配送方式,如果大家订过机票可能知道配送方式有 ...
- 通过HostOnly Cookie为Cookie正确的设置一级域名
前言 用户行为分析,最重要的一点就是通过埋点准确的获取用户的Cookie,那么这个Cookie到底怎么设置呢?那么如果面对的是站群,用户Cookie又该怎么设置,才能让访客量和新访客量准确无误呢? 接 ...
- Java的String.valueOf 转换 与、空串+类型变量转换与封装类(Integer)的toString方式转换比较。
1.空串+类型变量方式转换 int i=20; String s=""+i; 这种方式实际上经过了两个步骤,首先进行了i.ToString()把 i 转换为 字符串,然后再进行加法 ...
- background-position控制背景位置
提示:需要把 background-attachment 属性设置为 "fixed",才能保证该属性在 Firefox 和 Opera 中正常工作.