真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

NPOI讀取Excel表格類-創(chuàng)新互聯(lián)

 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);
           }
       }NPOI讀取Excel表格類

       public static ISheet CreateSheet(string sheetname, IWorkbook workbook)
       {
           return workbook.CreateSheet(sheetname);
       }

創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比渝北網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式渝北網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋渝北地區(qū)。費(fèi)用合理售后完善,十多年實(shí)體公司更值得信賴。

       public ISheet WriteToTemplate(IList datalist, string sheetname, int fieldstartrowindex, int fieldstartcolindex, int datastartrowindex)
       {
           return null;
       }

       public NPOIHelper(string filetemplatepath)
       {
           workbook = (HSSFWorkbook)LoadFromFile(filetemplatepath);

       }

       ///


       /// 將List對(duì)象轉(zhuǎn)為SHEET
       ///

       ///
       ///
       ///
       /// 表頭列
       /// 表數(shù)據(jù)列
       ///
       public int ConvertTOSheet(string sheetname, IList 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 fieldindexdic = new Dictionary();
           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 fieldtitle = fieldindexdic.Select(x => x.Value).Distinct();

           IDictionary pifdic = GetPropertyInfoDic(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 GetPropertyInfoDic(IEnumerable namelist)
           where T : new()
       {
           IDictionary pifdic = new Dictionary();
           PropertyInfo[] pifs = typeof(T).GetProperties();

           IEnumerable 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的數(shù)據(jù)讀取成MemoryStream
       public static MemoryStream RenderToExcel(DataTable dt)
       {
           MemoryStream ms = new MemoryStream();
           using (dt)
           {
               //創(chuàng)建Workbook
               HSSFWorkbook book = new HSSFWorkbook();
               ISheet sheet = book.CreateSheet(dt.TableName);
               //創(chuàng)建一個(gè)日期類型的格式
               ICellStyle dataStyle = book.CreateCellStyle();
               IDataFormat dataFormat = book.CreateDataFormat();
               dataStyle.DataFormat = dataFormat.GetFormat("yyyy-mm-dd");
               //創(chuàng)建表頭
               IRow row = sheet.CreateRow(0);
               foreach (DataColumn col in dt.Columns)
               {
                   //給表頭添加字段名字
                   row.CreateCell(col.Ordinal).SetCellValue(col.Caption);//Caption沒有值則獲取ColumnName
                   //設(shè)置列寬
                   sheet.SetColumnWidth(col.Ordinal, 30 * 110);
               }
               //創(chuàng)建數(shù)據(jù)行并添加值
               int rowIndex = 1;//標(biāo)記數(shù)據(jù)行的位置
               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"://浮點(diǎn)型
                           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;
                       }

                   }

                   //循環(huán)一行后i的值自增1
                   rowIndex++;
               }

               book.Write(ms);
               ms.Flush();
               ms.Position = 0;//指定內(nèi)存流的當(dāng)前位置
             }

           return ms;
       }
       #endregion

       #region 將DataReader的數(shù)據(jù)轉(zhuǎn)換成MemoryStream并返回
       public static MemoryStream RenderToExcel(IDataReader dataReader)
       {
           MemoryStream ms = new MemoryStream();
           using (dataReader)
           {
               HSSFWorkbook book = new HSSFWorkbook();
               ISheet sheet = book.CreateSheet("數(shù)據(jù)表1");
               //創(chuàng)建表頭
               IRow row = sheet.CreateRow(0);
               //列的數(shù)目
               int columnCount = dataReader.FieldCount;
               for (int i = 0; i < columnCount; i++)
               {
                   row.CreateCell(i).SetCellValue(dataReader.GetName(i));
               }

               //創(chuàng)建數(shù)據(jù)行
               int rowIndex = 1;
               while (dataReader.Read())//dataReader只能一行一行地讀取數(shù)據(jù)
               {
                   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)
       {
           // 設(shè)置編碼和附件格式
           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));

           //添加請(qǐng)求報(bào)文頭
           //context.Response.AddHeader("Content-Disposition", "attachment;fileName=" + fileName);
           context.Response.BinaryWrite(ms.ToArray());
           context.Response.End();
       }
       #endregion

       #region NPOI讀取Excel流的數(shù)據(jù)相關(guān)
       public DataTable ReadFromExcel(Stream excelStream)
       {
           DataTable dt = new DataTable();
           using (excelStream)
           {
               //創(chuàng)建WorkBook
               HSSFWorkbook book = new HSSFWorkbook(excelStream);
               ISheet sheet = book.GetSheetAt(0);//獲取第一個(gè)表
               //獲取第一行表頭
               IRow headRow = sheet.GetRow(0);
               //列數(shù)
               int columnCount = headRow.LastCellNum;//LastCellNum=PhysicalNumberOfCells
               int rowCount = sheet.LastRowNum;//LastRowNum=PhysicalNumberOfCellsRow-1
               //創(chuàng)建DataTable的表頭
               for (int i = headRow.FirstCellNum; i < columnCount; i++)
               {
                   DataColumn dc = new DataColumn(headRow.GetCell(i).StringCellValue.ToString());
                   dt.Columns.Add(dc);
               }
               //創(chuàng)建數(shù)據(jù)
               for (int i = (sheet.FirstRowNum + 1); i <= rowCount; i++)
               {
                   //一行一行地創(chuàng)建
                   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);//取第一個(gè)工作表
               StringBuilder builder = new StringBuilder();

               IRow headerRow = sheet.GetRow(0);//第一行為標(biāo)題行
               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條記錄一次批量插入到數(shù)據(jù)庫
                       //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

   }


網(wǎng)頁標(biāo)題:NPOI讀取Excel表格類-創(chuàng)新互聯(lián)
當(dāng)前網(wǎng)址:http://weahome.cn/article/piopj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部