| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471 |
- using System;
- using System.Collections.Generic;
- using System.Data;
- using System.IO;
- using System.Text;
- using System.Web;
- using NPOI;
- using NPOI.HPSF;
- using NPOI.HSSF;
- using NPOI.HSSF.UserModel;
- using NPOI.HSSF.Util;
- using NPOI.POIFS;
- using NPOI.SS.Formula.Eval;
- using NPOI.SS.UserModel;
- using NPOI.Util;
- using NPOI.SS;
- using NPOI.DDF;
- using NPOI.SS.Util;
- using System.Collections;
- using System.Text.RegularExpressions;
- public class NPOIHelper
- {
- #region 从datatable中将数据导出到excel
- /// <summary>
- /// DataTable导出到Excel的MemoryStream
- /// </summary>
- /// <param name="dtSource">源DataTable</param>
- /// <param name="strHeaderText">表头文本</param>
- static MemoryStream ExportDT(DataTable dtSource, string strHeaderText)
- {
- HSSFWorkbook workbook = new HSSFWorkbook();
- HSSFSheet sheet = workbook.CreateSheet() as HSSFSheet;
- #region 右击文件 属性信息
- //{
- // DocumentSummaryInformation dsi = PropertySetFactory.CreateDocumentSummaryInformation();
- // dsi.Company = "http://www.yongfa365.com/";
- // workbook.DocumentSummaryInformation = dsi;
- // SummaryInformation si = PropertySetFactory.CreateSummaryInformation();
- // si.Author = "柳永法"; //填加xls文件作者信息
- // si.ApplicationName = "NPOI测试程序"; //填加xls文件创建程序信息
- // si.LastAuthor = "柳永法2"; //填加xls文件最后保存者信息
- // si.Comments = "说明信息"; //填加xls文件作者信息
- // si.Title = "NPOI测试"; //填加xls文件标题信息
- // si.Subject = "NPOI测试Demo"; //填加文件主题信息
- // si.CreateDateTime = DateTime.Now;
- // workbook.SummaryInformation = si;
- //}
- #endregion
- HSSFCellStyle dateStyle = workbook.CreateCellStyle() as HSSFCellStyle;
- HSSFDataFormat format = workbook.CreateDataFormat() as HSSFDataFormat;
- dateStyle.DataFormat = format.GetFormat("yyyy-mm-dd");
- //取得列宽
- int[] arrColWidth = new int[dtSource.Columns.Count];
- foreach (DataColumn item in dtSource.Columns)
- {
- arrColWidth[item.Ordinal] = Encoding.GetEncoding(936).GetBytes(item.ColumnName.ToString()).Length;
- }
- for (int i = 0; i < dtSource.Rows.Count; i++)
- {
- for (int j = 0; j < dtSource.Columns.Count; j++)
- {
- int intTemp = Encoding.GetEncoding(936).GetBytes(dtSource.Rows[i][j].ToString()).Length;
- if (intTemp > arrColWidth[j])
- {
- arrColWidth[j] = intTemp;
- }
- }
- }
- int rowIndex = 0;
- foreach (DataRow row in dtSource.Rows)
- {
- #region 新建表,填充表头,填充列头,样式
- if (rowIndex == 65535 || rowIndex == 0)
- {
- if (rowIndex != 0)
- {
- sheet = workbook.CreateSheet() as HSSFSheet;
- }
- #region 表头及样式
- {
- HSSFRow headerRow = sheet.CreateRow(0) as HSSFRow;
- headerRow.HeightInPoints = 25;
- headerRow.CreateCell(0).SetCellValue(strHeaderText);
- HSSFCellStyle headStyle = workbook.CreateCellStyle() as HSSFCellStyle;
- headStyle.Alignment = NPOI.SS.UserModel.HorizontalAlignment.CENTER;
- HSSFFont font = workbook.CreateFont() as HSSFFont;
- font.FontHeightInPoints = 20;
- font.Boldweight = 700;
- headStyle.SetFont(font);
- headerRow.GetCell(0).CellStyle = headStyle;
- sheet.AddMergedRegion(new Region(0, 0, 0, dtSource.Columns.Count - 1));
- //headerRow.Dispose();
- }
- #endregion
- #region 列头及样式
- {
- HSSFRow headerRow = sheet.CreateRow(1) as HSSFRow;
- HSSFCellStyle headStyle = workbook.CreateCellStyle() as HSSFCellStyle;
- headStyle.Alignment = NPOI.SS.UserModel.HorizontalAlignment.CENTER;
- HSSFFont font = workbook.CreateFont() as HSSFFont;
- font.FontHeightInPoints = 10;
- font.Boldweight = 700;
- headStyle.SetFont(font);
- foreach (DataColumn column in dtSource.Columns)
- {
- headerRow.CreateCell(column.Ordinal).SetCellValue(column.ColumnName);
- headerRow.GetCell(column.Ordinal).CellStyle = headStyle;
- //设置列宽
- sheet.SetColumnWidth(column.Ordinal, (arrColWidth[column.Ordinal] + 1) * 256);
- }
- //headerRow.Dispose();
- }
- #endregion
- rowIndex = 2;
- }
- #endregion
- #region 填充内容
- HSSFRow dataRow = sheet.CreateRow(rowIndex) as HSSFRow;
- foreach (DataColumn column in dtSource.Columns)
- {
- HSSFCell newCell = dataRow.CreateCell(column.Ordinal) as HSSFCell;
- string drValue = row[column].ToString();
- switch (column.DataType.ToString())
- {
- case "System.String": //字符串类型
- double result;
- if (isNumeric(drValue, out result))
- {
- double.TryParse(drValue, out result);
- newCell.SetCellValue(result);
- break;
- }
- else
- {
- newCell.SetCellValue(drValue);
- break;
- }
- case "System.DateTime": //日期类型
- DateTime dateV;
- DateTime.TryParse(drValue, out dateV);
- newCell.SetCellValue(dateV);
- newCell.CellStyle = dateStyle; //格式化显示
- 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;
- }
- }
- #endregion
- rowIndex++;
- }
- using (MemoryStream ms = new MemoryStream())
- {
- workbook.Write(ms);
- ms.Flush();
- ms.Position = 0;
- //sheet.Dispose();
- //workbook.Dispose();
- return ms;
- }
- }
- /// <summary>
- /// DataTable导出到Excel的MemoryStream
- /// </summary>
- /// <param name="dtSource">源DataTable</param>
- /// <param name="strHeaderText">表头文本</param>
- static void ExportDTI(DataTable dtSource, string strHeaderText, FileStream fs)
- {
- XSSFWorkbook workbook = new XSSFWorkbook();
- XSSFSheet sheet = workbook.CreateSheet() as XSSFSheet;
- #region 右击文件 属性信息
- //{
- // DocumentSummaryInformation dsi = PropertySetFactory.CreateDocumentSummaryInformation();
- // dsi.Company = "http://www.yongfa365.com/";
- // workbook.DocumentSummaryInformation = dsi;
- // SummaryInformation si = PropertySetFactory.CreateSummaryInformation();
- // si.Author = "柳永法"; //填加xls文件作者信息
- // si.ApplicationName = "NPOI测试程序"; //填加xls文件创建程序信息
- // si.LastAuthor = "柳永法2"; //填加xls文件最后保存者信息
- // si.Comments = "说明信息"; //填加xls文件作者信息
- // si.Title = "NPOI测试"; //填加xls文件标题信息
- // si.Subject = "NPOI测试Demo"; //填加文件主题信息
- // si.CreateDateTime = DateTime.Now;
- // workbook.SummaryInformation = si;
- //}
- #endregion
- XSSFCellStyle dateStyle = workbook.CreateCellStyle() as XSSFCellStyle;
- XSSFDataFormat format = workbook.CreateDataFormat() as XSSFDataFormat;
- dateStyle.DataFormat = format.GetFormat("yyyy-mm-dd");
- //取得列宽
- int[] arrColWidth = new int[dtSource.Columns.Count];
- foreach (DataColumn item in dtSource.Columns)
- {
- arrColWidth[item.Ordinal] = Encoding.GetEncoding(936).GetBytes(item.ColumnName.ToString()).Length;
- }
- for (int i = 0; i < dtSource.Rows.Count; i++)
- {
- for (int j = 0; j < dtSource.Columns.Count; j++)
- {
- int intTemp = Encoding.GetEncoding(936).GetBytes(dtSource.Rows[i][j].ToString()).Length;
- if (intTemp > arrColWidth[j])
- {
- arrColWidth[j] = intTemp;
- }
- }
- }
- int rowIndex = 0;
- foreach (DataRow row in dtSource.Rows)
- {
- #region 新建表,填充表头,填充列头,样式
- if (rowIndex == 0)
- {
- #region 表头及样式
- //{
- // XSSFRow headerRow = sheet.CreateRow(0) as XSSFRow;
- // headerRow.HeightInPoints = 25;
- // headerRow.CreateCell(0).SetCellValue(strHeaderText);
- // XSSFCellStyle headStyle = workbook.CreateCellStyle() as XSSFCellStyle;
- // headStyle.Alignment = NPOI.SS.UserModel.HorizontalAlignment.CENTER;
- // XSSFFont font = workbook.CreateFont() as XSSFFont;
- // font.FontHeightInPoints = 20;
- // font.Boldweight = 700;
- // headStyle.SetFont(font);
- // headerRow.GetCell(0).CellStyle = headStyle;
- // //sheet.AddMergedRegion(new Region(0, 0, 0, dtSource.Columns.Count - 1));
- // //headerRow.Dispose();
- //}
- #endregion
- #region 列头及样式
- {
- XSSFRow headerRow = sheet.CreateRow(0) as XSSFRow;
- XSSFCellStyle headStyle = workbook.CreateCellStyle() as XSSFCellStyle;
- headStyle.Alignment = NPOI.SS.UserModel.HorizontalAlignment.CENTER;
- XSSFFont font = workbook.CreateFont() as XSSFFont;
- font.FontHeightInPoints = 10;
- font.Boldweight = 700;
- headStyle.SetFont(font);
- foreach (DataColumn column in dtSource.Columns)
- {
- headerRow.CreateCell(column.Ordinal).SetCellValue(column.ColumnName);
- headerRow.GetCell(column.Ordinal).CellStyle = headStyle;
- //设置列宽
- sheet.SetColumnWidth(column.Ordinal, (arrColWidth[column.Ordinal] + 1) * 256);
- }
- //headerRow.Dispose();
- }
- #endregion
- rowIndex = 1;
- }
- #endregion
- #region 填充内容
- XSSFRow dataRow = sheet.CreateRow(rowIndex) as XSSFRow;
- foreach (DataColumn column in dtSource.Columns)
- {
- XSSFCell newCell = dataRow.CreateCell(column.Ordinal) as XSSFCell;
- string drValue = row[column].ToString();
- switch (column.DataType.ToString())
- {
- case "System.String": //字符串类型
- double result;
- if (isNumeric(drValue, out result))
- {
- double.TryParse(drValue, out result);
- newCell.SetCellValue(result);
- break;
- }
- else
- {
- newCell.SetCellValue(drValue);
- break;
- }
- case "System.DateTime": //日期类型
- DateTime dateV;
- DateTime.TryParse(drValue, out dateV);
- newCell.SetCellValue(dateV);
- newCell.CellStyle = dateStyle; //格式化显示
- 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;
- }
- }
- #endregion
- rowIndex++;
- }
- workbook.Write(fs);
- fs.Close();
- }
- /// <summary>
- /// DataTable导出到Excel文件
- /// </summary>
- /// <param name="dtSource">源DataTable</param>
- /// <param name="strHeaderText">表头文本</param>
- /// <param name="strFileName">保存位置</param>
- public static void ExportDTtoExcel(DataTable dtSource, string strHeaderText, string strFileName)
- {
- string[] temp = strFileName.Split('.');
- if (temp[temp.Length - 1] == "xls" && dtSource.Columns.Count < 256 && dtSource.Rows.Count < 65536)
- {
- using (MemoryStream ms = ExportDT(dtSource, strHeaderText))
- {
- using (FileStream fs = new FileStream(strFileName, FileMode.Create, FileAccess.Write))
- {
- byte[] data = ms.ToArray();
- fs.Write(data, 0, data.Length);
- fs.Flush();
- }
- }
- }
- else
- {
- if (temp[temp.Length - 1] == "xls")
- strFileName = strFileName + "x";
- using (FileStream fs = new FileStream(strFileName, FileMode.Create, FileAccess.Write))
- {
- ExportDTI(dtSource, strHeaderText, fs);
- }
- }
- }
- #endregion
- #region 从excel中将数据导出到datatable
- /// <summary>
- /// 读取excel 默认第一行为标头
- /// </summary>
- /// <param name="strFileName">excel文档路径</param>
- /// <returns></returns>
- public static DataTable ImportExceltoDt(string strFileName)
- {
- DataTable dt = new DataTable();
- IWorkbook wb;
- using (FileStream file = new FileStream(strFileName, FileMode.Open, FileAccess.Read))
- {
- wb = WorkbookFactory.Create(file);
- }
- ISheet sheet = wb.GetSheetAt(0);
- dt = ImportDt(sheet, 0, true);
- return dt;
- }
- /// <summary>
- /// 读取Excel流到DataTable
- /// </summary>
- /// <param name="stream">Excel流</param>
- /// <returns>第一个sheet中的数据</returns>
- public static DataTable ImportExceltoDt(Stream stream)
- {
- try
- {
- DataTable dt = new DataTable();
- IWorkbook wb;
- using (stream)
- {
- wb = WorkbookFactory.Create(stream);
- }
- ISheet sheet = wb.GetSheetAt(0);
- dt = ImportDt(sheet, 0, true);
- return dt;
- }
- catch (Exception)
- {
- throw;
- }
- }
- /// <summary>
- /// 读取Excel流到DataTable
- /// </summary>
- /// <param name="stream">Excel流</param>
- /// <param name="sheetName">表单名</param>
- /// <param name="HeaderRowIndex">列头所在行号,-1表示没有列头</param>
- /// <returns>指定sheet中的数据</returns>
- public static DataTable ImportExceltoDt(Stream stream, string sheetName, int HeaderRowIndex)
- {
- try
- {
- DataTable dt = new DataTable();
- IWorkbook wb;
- using (stream)
- {
- wb = WorkbookFactory.Create(stream);
- }
- ISheet sheet = wb.GetSheet(sheetName);
- dt = ImportDt(sheet, HeaderRowIndex, true);
- return dt;
- }
- catch (Exception)
- {
- throw;
- }
- }
- /// <summary>
- /// 读取Excel流到DataSet
- /// </summary>
- /// <param name="stream">Excel流</param>
- /// <returns>Excel中的数据</returns>
- public static DataSet ImportExceltoDs(Stream stream)
- {
- try
- {
- DataSet ds = new DataSet();
- IWorkbook wb;
- using (stream)
- {
- wb = WorkbookFactory.Create(stream);
- }
- for (int i = 0; i < wb.NumberOfSheets; i++)
- {
- DataTable dt = new DataTable();
- ISheet sheet = wb.GetSheetAt(i);
- dt = ImportDt(sheet, 0, true);
- ds.Tables.Add(dt);
- }
- return ds;
- }
- catch (Exception)
- {
- throw;
- }
- }
- /// <summary>
- /// 读取Excel流到DataSet
- /// </summary>
- /// <param name="stream">Excel流</param>
- /// <param name="dict">字典参数,key:sheet名,value:列头所在行号,-1表示没有列头</param>
- /// <returns>Excel中的数据</returns>
- public static DataSet ImportExceltoDs(Stream stream, Dictionary<string, int> dict)
- {
- try
- {
- DataSet ds = new DataSet();
- IWorkbook wb;
- using (stream)
- {
- wb = WorkbookFactory.Create(stream);
- }
- foreach (string key in dict.Keys)
- {
- DataTable dt = new DataTable();
- ISheet sheet = wb.GetSheet(key);
- dt = ImportDt(sheet, dict[key], true);
- ds.Tables.Add(dt);
- }
- return ds;
- }
- catch (Exception)
- {
- throw;
- }
- }
- /// <summary>
- /// 读取excel
- /// </summary>
- /// <param name="strFileName">excel文件路径</param>
- /// <param name="sheet">需要导出的sheet</param>
- /// <param name="HeaderRowIndex">列头所在行号,-1表示没有列头</param>
- /// <returns></returns>
- public static DataTable ImportExceltoDt(string strFileName, string SheetName, int HeaderRowIndex)
- {
- HSSFWorkbook workbook;
- IWorkbook wb;
- using (FileStream file = new FileStream(strFileName, FileMode.Open, FileAccess.Read))
- {
- wb = new HSSFWorkbook(file);
- }
- ISheet sheet = wb.GetSheet(SheetName);
- DataTable table = new DataTable();
- table = ImportDt(sheet, HeaderRowIndex, true);
- //ExcelFileStream.Close();
- workbook = null;
- sheet = null;
- return table;
- }
- /// <summary>
- /// 读取excel
- /// </summary>
- /// <param name="strFileName">excel文件路径</param>
- /// <param name="sheet">需要导出的sheet序号</param>
- /// <param name="HeaderRowIndex">列头所在行号,-1表示没有列头</param>
- /// <returns></returns>
- public static DataTable ImportExceltoDt(string strFileName, int SheetIndex, int HeaderRowIndex)
- {
- HSSFWorkbook workbook;
- IWorkbook wb;
- using (FileStream file = new FileStream(strFileName, FileMode.Open, FileAccess.Read))
- {
- wb = WorkbookFactory.Create(file);
- }
- ISheet isheet = wb.GetSheetAt(SheetIndex);
- DataTable table = new DataTable();
- table = ImportDt(isheet, HeaderRowIndex, true);
- //ExcelFileStream.Close();
- workbook = null;
- isheet = null;
- return table;
- }
- /// <summary>
- /// 读取excel
- /// </summary>
- /// <param name="strFileName">excel文件路径</param>
- /// <param name="sheet">需要导出的sheet</param>
- /// <param name="HeaderRowIndex">列头所在行号,-1表示没有列头</param>
- /// <returns></returns>
- public static DataTable ImportExceltoDt(string strFileName, string SheetName, int HeaderRowIndex, bool needHeader)
- {
- HSSFWorkbook workbook;
- IWorkbook wb;
- using (FileStream file = new FileStream(strFileName, FileMode.Open, FileAccess.Read))
- {
- wb = WorkbookFactory.Create(file);
- }
- ISheet sheet = wb.GetSheet(SheetName);
- DataTable table = new DataTable();
- table = ImportDt(sheet, HeaderRowIndex, needHeader);
- //ExcelFileStream.Close();
- workbook = null;
- sheet = null;
- return table;
- }
- /// <summary>
- /// 读取excel
- /// </summary>
- /// <param name="strFileName">excel文件路径</param>
- /// <param name="sheet">需要导出的sheet序号</param>
- /// <param name="HeaderRowIndex">列头所在行号,-1表示没有列头</param>
- /// <returns></returns>
- public static DataTable ImportExceltoDt(string strFileName, int SheetIndex, int HeaderRowIndex, bool needHeader)
- {
- HSSFWorkbook workbook;
- IWorkbook wb;
- using (FileStream file = new FileStream(strFileName, FileMode.Open, FileAccess.Read))
- {
- wb = WorkbookFactory.Create(file);
- }
- ISheet sheet = wb.GetSheetAt(SheetIndex);
- DataTable table = new DataTable();
- table = ImportDt(sheet, HeaderRowIndex, needHeader);
- //ExcelFileStream.Close();
- workbook = null;
- sheet = null;
- return table;
- }
- /// <summary>
- /// 将制定sheet中的数据导出到datatable中
- /// </summary>
- /// <param name="sheet">需要导出的sheet</param>
- /// <param name="HeaderRowIndex">列头所在行号,-1表示没有列头</param>
- /// <returns></returns>
- static DataTable ImportDt(ISheet sheet, int HeaderRowIndex, bool needHeader)
- {
- DataTable table = new DataTable();
- IRow headerRow;
- int cellCount;
- try
- {
- if (HeaderRowIndex < 0 || !needHeader)
- {
- headerRow = sheet.GetRow(0);
- cellCount = headerRow.LastCellNum;
- for (int i = headerRow.FirstCellNum; i <= cellCount; i++)
- {
- DataColumn column = new DataColumn(Convert.ToString(i));
- table.Columns.Add(column);
- }
- }
- else
- {
- headerRow = sheet.GetRow(HeaderRowIndex);
- cellCount = headerRow.LastCellNum;
- for (int i = headerRow.FirstCellNum; i <= cellCount; i++)
- {
- if (headerRow.GetCell(i) == null)
- {
- if (table.Columns.IndexOf(Convert.ToString(i)) > 0)
- {
- DataColumn column = new DataColumn(Convert.ToString("重复列名" + i));
- table.Columns.Add(column);
- }
- else
- {
- DataColumn column = new DataColumn(Convert.ToString(i));
- table.Columns.Add(column);
- }
- }
- else if (table.Columns.IndexOf(headerRow.GetCell(i).ToString()) > 0)
- {
- DataColumn column = new DataColumn(Convert.ToString("重复列名" + i));
- table.Columns.Add(column);
- }
- else
- {
- DataColumn column = new DataColumn(headerRow.GetCell(i).ToString());
- table.Columns.Add(column);
- }
- }
- }
- int rowCount = sheet.LastRowNum;
- for (int i = (HeaderRowIndex + 1); i <= sheet.LastRowNum; i++)
- {
- try
- {
- IRow row;
- if (sheet.GetRow(i) == null)
- {
- row = sheet.CreateRow(i);
- }
- else
- {
- row = sheet.GetRow(i);
- }
- DataRow dataRow = table.NewRow();
- for (int j = row.FirstCellNum; j <= cellCount; j++)
- {
- try
- {
- if (row.GetCell(j) != null)
- {
- switch (row.GetCell(j).CellType)
- {
- case CellType.STRING:
- string str = row.GetCell(j).StringCellValue;
- if (str != null && str.Length > 0)
- {
- dataRow[j] = str.ToString();
- }
- else
- {
- dataRow[j] = null;
- }
- break;
- case CellType.NUMERIC:
- if (DateUtil.IsCellDateFormatted(row.GetCell(j)))
- {
- dataRow[j] = DateTime.FromOADate(row.GetCell(j).NumericCellValue);
- }
- else
- {
- dataRow[j] = Convert.ToDouble(row.GetCell(j).NumericCellValue);
- }
- break;
- case CellType.BOOLEAN:
- dataRow[j] = Convert.ToString(row.GetCell(j).BooleanCellValue);
- break;
- case CellType.ERROR:
- dataRow[j] = ErrorEval.GetText(row.GetCell(j).ErrorCellValue);
- break;
- case CellType.FORMULA:
- switch (row.GetCell(j).CachedFormulaResultType)
- {
- case CellType.STRING:
- string strFORMULA = row.GetCell(j).StringCellValue;
- if (strFORMULA != null && strFORMULA.Length > 0)
- {
- dataRow[j] = strFORMULA.ToString();
- }
- else
- {
- dataRow[j] = null;
- }
- break;
- case CellType.NUMERIC:
- dataRow[j] = Convert.ToString(row.GetCell(j).NumericCellValue);
- break;
- case CellType.BOOLEAN:
- dataRow[j] = Convert.ToString(row.GetCell(j).BooleanCellValue);
- break;
- case CellType.ERROR:
- dataRow[j] = ErrorEval.GetText(row.GetCell(j).ErrorCellValue);
- break;
- default:
- dataRow[j] = "";
- break;
- }
- break;
- default:
- dataRow[j] = "";
- break;
- }
- }
- }
- catch (Exception exception)
- {
- wl.WriteLogs(exception.ToString());
- }
- }
- table.Rows.Add(dataRow);
- }
- catch (Exception exception)
- {
- wl.WriteLogs(exception.ToString());
- }
- }
- }
- catch (Exception exception)
- {
- wl.WriteLogs(exception.ToString());
- }
- return table;
- }
- #endregion
- public static void InsertSheet(string outputFile, string sheetname, DataTable dt)
- {
- FileStream readfile = new FileStream(outputFile, FileMode.Open, FileAccess.Read);
- IWorkbook hssfworkbook = WorkbookFactory.Create(readfile);
- //HSSFWorkbook hssfworkbook = new HSSFWorkbook(readfile);
- int num = hssfworkbook.GetSheetIndex(sheetname);
- ISheet sheet1;
- if (num >= 0)
- sheet1 = hssfworkbook.GetSheet(sheetname);
- else
- {
- sheet1 = hssfworkbook.CreateSheet(sheetname);
- }
- try
- {
- if (sheet1.GetRow(0) == null)
- {
- sheet1.CreateRow(0);
- }
- for (int coluid = 0; coluid < dt.Columns.Count; coluid++)
- {
- if (sheet1.GetRow(0).GetCell(coluid) == null)
- {
- sheet1.GetRow(0).CreateCell(coluid);
- }
- sheet1.GetRow(0).GetCell(coluid).SetCellValue(dt.Columns[coluid].ColumnName);
- }
- }
- catch (Exception ex)
- {
- wl.WriteLogs(ex.ToString());
- throw;
- }
- for (int i = 1; i <= dt.Rows.Count; i++)
- {
- try
- {
- if (sheet1.GetRow(i) == null)
- {
- sheet1.CreateRow(i);
- }
- for (int coluid = 0; coluid < dt.Columns.Count; coluid++)
- {
- if (sheet1.GetRow(i).GetCell(coluid) == null)
- {
- sheet1.GetRow(i).CreateCell(coluid);
- }
- sheet1.GetRow(i).GetCell(coluid).SetCellValue(dt.Rows[i - 1][coluid].ToString());
- }
- }
- catch (Exception ex)
- {
- wl.WriteLogs(ex.ToString());
- //throw;
- }
- }
- try
- {
- readfile.Close();
- FileStream writefile = new FileStream(outputFile, FileMode.OpenOrCreate, FileAccess.Write);
- hssfworkbook.Write(writefile);
- writefile.Close();
- }
- catch (Exception ex)
- {
- wl.WriteLogs(ex.ToString());
- }
- }
- #region 更新excel中的数据
- /// <summary>
- /// 更新Excel表格
- /// </summary>
- /// <param name="outputFile">需更新的excel表格路径</param>
- /// <param name="sheetname">sheet名</param>
- /// <param name="updateData">需更新的数据</param>
- /// <param name="coluid">需更新的列号</param>
- /// <param name="rowid">需更新的开始行号</param>
- public static void UpdateExcel(string outputFile, string sheetname, string[] updateData, int coluid, int rowid)
- {
- //FileStream readfile = new FileStream(outputFile, FileMode.Open, FileAccess.Read);
- IWorkbook hssfworkbook = null;// WorkbookFactory.Create(outputFile);
- //HSSFWorkbook hssfworkbook = new HSSFWorkbook(readfile);
- ISheet sheet1 = hssfworkbook.GetSheet(sheetname);
- for (int i = 0; i < updateData.Length; i++)
- {
- try
- {
- if (sheet1.GetRow(i + rowid) == null)
- {
- sheet1.CreateRow(i + rowid);
- }
- if (sheet1.GetRow(i + rowid).GetCell(coluid) == null)
- {
- sheet1.GetRow(i + rowid).CreateCell(coluid);
- }
- sheet1.GetRow(i + rowid).GetCell(coluid).SetCellValue(updateData[i]);
- }
- catch (Exception ex)
- {
- wl.WriteLogs(ex.ToString());
- throw;
- }
- }
- try
- {
- //readfile.Close();
- FileStream writefile = new FileStream(outputFile, FileMode.OpenOrCreate, FileAccess.Write);
- hssfworkbook.Write(writefile);
- writefile.Close();
- }
- catch (Exception ex)
- {
- wl.WriteLogs(ex.ToString());
- }
- }
- /// <summary>
- /// 更新Excel表格
- /// </summary>
- /// <param name="outputFile">需更新的excel表格路径</param>
- /// <param name="sheetname">sheet名</param>
- /// <param name="updateData">需更新的数据</param>
- /// <param name="coluids">需更新的列号</param>
- /// <param name="rowid">需更新的开始行号</param>
- public static void UpdateExcel(string outputFile, string sheetname, string[][] updateData, int[] coluids, int rowid)
- {
- FileStream readfile = new FileStream(outputFile, FileMode.Open, FileAccess.Read);
- HSSFWorkbook hssfworkbook = new HSSFWorkbook(readfile);
- readfile.Close();
- ISheet sheet1 = hssfworkbook.GetSheet(sheetname);
- for (int j = 0; j < coluids.Length; j++)
- {
- for (int i = 0; i < updateData[j].Length; i++)
- {
- try
- {
- if (sheet1.GetRow(i + rowid) == null)
- {
- sheet1.CreateRow(i + rowid);
- }
- if (sheet1.GetRow(i + rowid).GetCell(coluids[j]) == null)
- {
- sheet1.GetRow(i + rowid).CreateCell(coluids[j]);
- }
- sheet1.GetRow(i + rowid).GetCell(coluids[j]).SetCellValue(updateData[j][i]);
- }
- catch (Exception ex)
- {
- wl.WriteLogs(ex.ToString());
- }
- }
- }
- try
- {
- FileStream writefile = new FileStream(outputFile, FileMode.Create);
- hssfworkbook.Write(writefile);
- writefile.Close();
- }
- catch (Exception ex)
- {
- wl.WriteLogs(ex.ToString());
- }
- }
- /// <summary>
- /// 更新Excel表格
- /// </summary>
- /// <param name="outputFile">需更新的excel表格路径</param>
- /// <param name="sheetname">sheet名</param>
- /// <param name="updateData">需更新的数据</param>
- /// <param name="coluid">需更新的列号</param>
- /// <param name="rowid">需更新的开始行号</param>
- public static void UpdateExcel(string outputFile, string sheetname, double[] updateData, int coluid, int rowid)
- {
- FileStream readfile = new FileStream(outputFile, FileMode.Open, FileAccess.Read);
- HSSFWorkbook hssfworkbook = new HSSFWorkbook(readfile);
- ISheet sheet1 = hssfworkbook.GetSheet(sheetname);
- for (int i = 0; i < updateData.Length; i++)
- {
- try
- {
- if (sheet1.GetRow(i + rowid) == null)
- {
- sheet1.CreateRow(i + rowid);
- }
- if (sheet1.GetRow(i + rowid).GetCell(coluid) == null)
- {
- sheet1.GetRow(i + rowid).CreateCell(coluid);
- }
- sheet1.GetRow(i + rowid).GetCell(coluid).SetCellValue(updateData[i]);
- }
- catch (Exception ex)
- {
- wl.WriteLogs(ex.ToString());
- throw;
- }
- }
- try
- {
- readfile.Close();
- FileStream writefile = new FileStream(outputFile, FileMode.Create, FileAccess.Write);
- hssfworkbook.Write(writefile);
- writefile.Close();
- }
- catch (Exception ex)
- {
- wl.WriteLogs(ex.ToString());
- }
- }
- /// <summary>
- /// 更新Excel表格
- /// </summary>
- /// <param name="outputFile">需更新的excel表格路径</param>
- /// <param name="sheetname">sheet名</param>
- /// <param name="updateData">需更新的数据</param>
- /// <param name="coluids">需更新的列号</param>
- /// <param name="rowid">需更新的开始行号</param>
- public static void UpdateExcel(string outputFile, string sheetname, double[][] updateData, int[] coluids, int rowid)
- {
- FileStream readfile = new FileStream(outputFile, FileMode.Open, FileAccess.Read);
- HSSFWorkbook hssfworkbook = new HSSFWorkbook(readfile);
- readfile.Close();
- ISheet sheet1 = hssfworkbook.GetSheet(sheetname);
- for (int j = 0; j < coluids.Length; j++)
- {
- for (int i = 0; i < updateData[j].Length; i++)
- {
- try
- {
- if (sheet1.GetRow(i + rowid) == null)
- {
- sheet1.CreateRow(i + rowid);
- }
- if (sheet1.GetRow(i + rowid).GetCell(coluids[j]) == null)
- {
- sheet1.GetRow(i + rowid).CreateCell(coluids[j]);
- }
- sheet1.GetRow(i + rowid).GetCell(coluids[j]).SetCellValue(updateData[j][i]);
- }
- catch (Exception ex)
- {
- wl.WriteLogs(ex.ToString());
- }
- }
- }
- try
- {
- FileStream writefile = new FileStream(outputFile, FileMode.Create);
- hssfworkbook.Write(writefile);
- writefile.Close();
- }
- catch (Exception ex)
- {
- wl.WriteLogs(ex.ToString());
- }
- }
- #endregion
- public static int GetSheetNumber(string outputFile)
- {
- int number = 0;
- try
- {
- FileStream readfile = new FileStream(outputFile, FileMode.Open, FileAccess.Read);
- HSSFWorkbook hssfworkbook = new HSSFWorkbook(readfile);
- number = hssfworkbook.NumberOfSheets;
- }
- catch (Exception exception)
- {
- wl.WriteLogs(exception.ToString());
- }
- return number;
- }
- public static ArrayList GetSheetName(string outputFile)
- {
- ArrayList arrayList = new ArrayList();
- try
- {
- FileStream readfile = new FileStream(outputFile, FileMode.Open, FileAccess.Read);
- HSSFWorkbook hssfworkbook = new HSSFWorkbook(readfile);
- for (int i = 0; i < hssfworkbook.NumberOfSheets; i++)
- {
- arrayList.Add(hssfworkbook.GetSheetName(i));
- }
- }
- catch (Exception exception)
- {
- wl.WriteLogs(exception.ToString());
- }
- return arrayList;
- }
- public static bool isNumeric(String message, out double result)
- {
- Regex rex = new Regex(@"^[-]?\d+[.]?\d*$");
- result = -1;
- if (rex.IsMatch(message))
- {
- result = double.Parse(message);
- return true;
- }
- else
- return false;
- }
- ////////// 现用导出 \\\\\\\\\\
- /// <summary>
- /// 用于Web导出 第一步
- /// </summary>
- /// <param name="dtSource">源DataTable</param>
- /// <param name="strHeaderText">表头文本</param>
- /// <param name="strFileName">文件名</param>
- public static void ExportByWeb(DataTable dtSource, string strHeaderText, string strFileName)
- {
- HttpContext curContext = HttpContext.Current;
- // 设置编码和附件格式
- curContext.Response.ContentType = "application/vnd.ms-excel";
- curContext.Response.ContentEncoding = Encoding.UTF8;
- curContext.Response.Charset = "";
- curContext.Response.AppendHeader("Content-Disposition",
- "attachment;filename=" + HttpUtility.UrlEncode(strFileName, Encoding.UTF8));
- curContext.Response.BinaryWrite(Export(dtSource, strHeaderText).GetBuffer());
- curContext.Response.End();
- }
- /// <summary>
- /// DataTable导出到Excel的MemoryStream 第二步
- /// </summary>
- /// <param name="dtSource">源DataTable</param>
- /// <param name="strHeaderText">表头文本</param>
- public static MemoryStream Export(DataTable dtSource, string strHeaderText)
- {
- HSSFWorkbook workbook = new HSSFWorkbook();
- HSSFSheet sheet = workbook.CreateSheet() as HSSFSheet;
- #region 右击文件 属性信息
- {
- DocumentSummaryInformation dsi = PropertySetFactory.CreateDocumentSummaryInformation();
- dsi.Company = "NPOI";
- workbook.DocumentSummaryInformation = dsi;
- SummaryInformation si = PropertySetFactory.CreateSummaryInformation();
- si.Author = "文件作者信息"; //填加xls文件作者信息
- si.ApplicationName = "创建程序信息"; //填加xls文件创建程序信息
- si.LastAuthor = "最后保存者信息"; //填加xls文件最后保存者信息
- si.Comments = "作者信息"; //填加xls文件作者信息
- si.Title = "标题信息"; //填加xls文件标题信息
- si.Subject = "主题信息";//填加文件主题信息
- si.CreateDateTime = DateTime.Now;
- workbook.SummaryInformation = si;
- }
- #endregion
- HSSFCellStyle dateStyle = workbook.CreateCellStyle() as HSSFCellStyle;
- HSSFDataFormat format = workbook.CreateDataFormat() as HSSFDataFormat;
- dateStyle.DataFormat = format.GetFormat("yyyy-mm-dd");
- //取得列宽
- int[] arrColWidth = new int[dtSource.Columns.Count];
- foreach (DataColumn item in dtSource.Columns)
- {
- arrColWidth[item.Ordinal] = Encoding.GetEncoding(936).GetBytes(item.ColumnName.ToString()).Length;
- }
- for (int i = 0; i < dtSource.Rows.Count; i++)
- {
- for (int j = 0; j < dtSource.Columns.Count; j++)
- {
- int intTemp = Encoding.GetEncoding(936).GetBytes(dtSource.Rows[i][j].ToString()).Length;
- if (intTemp > arrColWidth[j])
- {
- arrColWidth[j] = intTemp;
- }
- }
- }
- int rowIndex = 0;
- foreach (DataRow row in dtSource.Rows)
- {
- #region 新建表,填充表头,填充列头,样式
- if (rowIndex == 65535 || rowIndex == 0)
- {
- if (rowIndex != 0)
- {
- sheet = workbook.CreateSheet() as HSSFSheet;
- }
- #region 表头及样式
- {
- if (string.IsNullOrEmpty(strHeaderText))
- {
- HSSFRow headerRow = sheet.CreateRow(0) as HSSFRow;
- headerRow.HeightInPoints = 25;
- headerRow.CreateCell(0).SetCellValue(strHeaderText);
- HSSFCellStyle headStyle = workbook.CreateCellStyle() as HSSFCellStyle;
- //headStyle.Alignment = CellHorizontalAlignment.CENTER;
- HSSFFont font = workbook.CreateFont() as HSSFFont;
- font.FontHeightInPoints = 20;
- font.Boldweight = 700;
- headStyle.SetFont(font);
- headerRow.GetCell(0).CellStyle = headStyle;
- sheet.AddMergedRegion(new Region(0, 0, 0, dtSource.Columns.Count - 1));
- //headerRow.Dispose();
- }
- }
- #endregion
- #region 列头及样式
- {
- HSSFRow headerRow = sheet.CreateRow(0) as HSSFRow;
- HSSFCellStyle headStyle = workbook.CreateCellStyle() as HSSFCellStyle;
- //headStyle.Alignment = CellHorizontalAlignment.CENTER;
- HSSFFont font = workbook.CreateFont() as HSSFFont;
- font.FontHeightInPoints = 10;
- font.Boldweight = 700;
- headStyle.SetFont(font);
- foreach (DataColumn column in dtSource.Columns)
- {
- headerRow.CreateCell(column.Ordinal).SetCellValue(column.ColumnName);
- headerRow.GetCell(column.Ordinal).CellStyle = headStyle;
- //设置列宽
- sheet.SetColumnWidth(column.Ordinal, (arrColWidth[column.Ordinal] + 1) * 256);
- }
- //headerRow.Dispose();
- }
- #endregion
- rowIndex = 1;
- }
- #endregion
- #region 填充内容
- HSSFRow dataRow = sheet.CreateRow(rowIndex) as HSSFRow;
- foreach (DataColumn column in dtSource.Columns)
- {
- HSSFCell newCell = dataRow.CreateCell(column.Ordinal) as HSSFCell;
- string drValue = row[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.CellStyle = dateStyle;//格式化显示
- 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;
- }
- }
- #endregion
- rowIndex++;
- }
- using (MemoryStream ms = new MemoryStream())
- {
- workbook.Write(ms);
- ms.Flush();
- ms.Position = 0;
- //sheet.Dispose();
- //workbook.Dispose();//一般只用写这一个就OK了,他会遍历并释放所有资源,但当前版本有问题所以只释放sheet
- return ms;
- }
- }
- /// <summary>
- /// /注:分浏览器进行编码(IE必须编码,FireFox不能编码,Chrome可编码也可不编码)
- /// </summary>
- /// <param name="ds"></param>
- /// <param name="strHeaderText"></param>
- /// <param name="strFileName"></param>
- public static void ExportByWeb(DataSet ds, string strHeaderText, string strFileName)
- {
- HttpContext curContext = HttpContext.Current;
- curContext.Response.ContentType = "application/vnd.ms-excel";
- curContext.Response.Charset = "";
- if (curContext.Request.UserAgent.ToLower().IndexOf("firefox", System.StringComparison.Ordinal) > 0)
- {
- curContext.Response.AppendHeader("Content-Disposition", "attachment;filename=" + strFileName);
- }
- else
- {
- curContext.Response.AppendHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(strFileName, System.Text.Encoding.UTF8));
- }
- // curContext.Response.AppendHeader("Content-Disposition", "attachment;filename=" +strFileName);
- curContext.Response.ContentEncoding = System.Text.Encoding.GetEncoding("utf-8");
- curContext.Response.BinaryWrite(ExportDataSetToExcel(ds, strHeaderText).GetBuffer());
- curContext.Response.End();
- }
- /// <summary>
- /// 由DataSet导出Excel
- /// </summary>
- /// <param name="sourceTable">要导出数据的DataTable</param>
- /// <param name="sheetName">工作表名称</param>
- /// <returns>Excel工作表</returns>
- private static MemoryStream ExportDataSetToExcel(DataSet sourceDs, string sheetName)
- {
- HSSFWorkbook workbook = new HSSFWorkbook();
- MemoryStream ms = new MemoryStream();
- string[] sheetNames = sheetName.Split(',');
- for (int i = 0; i < sheetNames.Length; i++)
- {
- ISheet sheet = workbook.CreateSheet(sheetNames[i]);
- #region 列头
- IRow headerRow = sheet.CreateRow(0);
- HSSFCellStyle headStyle = workbook.CreateCellStyle() as HSSFCellStyle;
- HSSFFont font = workbook.CreateFont() as HSSFFont;
- font.FontHeightInPoints = 10;
- font.Boldweight = 700;
- headStyle.SetFont(font);
- //取得列宽
- int[] arrColWidth = new int[sourceDs.Tables[i].Columns.Count];
- foreach (DataColumn item in sourceDs.Tables[i].Columns)
- {
- arrColWidth[item.Ordinal] = Encoding.GetEncoding(936).GetBytes(item.ColumnName.ToString()).Length;
- }
- // 处理列头
- foreach (DataColumn column in sourceDs.Tables[i].Columns)
- {
- headerRow.CreateCell(column.Ordinal).SetCellValue(column.ColumnName);
- headerRow.GetCell(column.Ordinal).CellStyle = headStyle;
- //设置列宽
- sheet.SetColumnWidth(column.Ordinal, (arrColWidth[column.Ordinal] + 1) * 256);
- }
- #endregion
- #region 填充值
- int rowIndex = 1;
- foreach (DataRow row in sourceDs.Tables[i].Rows)
- {
- IRow dataRow = sheet.CreateRow(rowIndex);
- foreach (DataColumn column in sourceDs.Tables[i].Columns)
- {
- dataRow.CreateCell(column.Ordinal).SetCellValue(row[column].ToString());
- }
- rowIndex++;
- }
- #endregion
- }
- workbook.Write(ms);
- ms.Flush();
- ms.Position = 0;
- workbook = null;
- return ms;
- }
- /// <summary>
- /// 验证导入的Excel是否有数据
- /// </summary>
- /// <param name="excelFileStream"></param>
- /// <returns></returns>
- public static bool HasData(Stream excelFileStream)
- {
- using (excelFileStream)
- {
- IWorkbook workBook = new HSSFWorkbook(excelFileStream);
- if (workBook.NumberOfSheets > 0)
- {
- ISheet sheet = workBook.GetSheetAt(0);
- return sheet.PhysicalNumberOfRows > 0;
- }
- }
- return false;
- }
- }
|