国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C# > 正文

C#通過NPOI操作Excel的實(shí)例代碼

2020-01-24 00:51:01
字體:
供稿:網(wǎng)友

C#操作Excel的方法有很多種,常見的有微軟官方的OLE Automation,Apache的POI等。這里介紹的是POI翻譯成C#的NPOI。

POI是Apache的通過Java操作Office的一個(gè)API,可以對(duì)Excel,Word,PPT等進(jìn)行操作,十分的強(qiáng)大。然后就被翻譯成C#版本的NPOI了,和log4j與log4net很相似。

好像在NPOI的.net4.0版本之前是不支持office2007及以上的XML格式的,但是最新的版本已經(jīng)支持了。只需要下載并引用下面五個(gè)程序集就能使用了。

這里提供一個(gè)操作Excel的類,類中提供了4個(gè)方法,兩個(gè)導(dǎo)出,兩個(gè)導(dǎo)入。可以通過DataSet導(dǎo)出擁有多個(gè)Sheet的Excel文件,也可以通過DataTable導(dǎo)出擁有一個(gè)Sheet的Excel。導(dǎo)入也是一樣,通過指定Sheet索引,導(dǎo)出DataTable,或者直接導(dǎo)出所有Sheet返回一個(gè)DataSet。

public class ExcelHelper  {    /// <summary>    /// 根據(jù)Excel和Sheet返回DataTable    /// </summary>    /// <param name="filePath">Excel文件地址</param>    /// <param name="sheetIndex">Sheet索引</param>    /// <returns>DataTable</returns>    public static DataTable GetDataTable(string filePath, int sheetIndex)    {      return GetDataSet(filePath, sheetIndex).Tables[0];    }    /// <summary>    /// 根據(jù)Excel返回DataSet    /// </summary>    /// <param name="filePath">Excel文件地址</param>    /// <param name="sheetIndex">Sheet索引,可選,默認(rèn)返回所有Sheet</param>    /// <returns>DataSet</returns>    public static DataSet GetDataSet(string filePath, int? sheetIndex = null)    {      DataSet ds = new DataSet();      IWorkbook fileWorkbook;      using (FileStream fs = new FileStream(filePath, FileMode.Open, FileAccess.Read))      {        if (filePath.Last() == 's')        {          try          {            fileWorkbook = new HSSFWorkbook(fs);          }          catch (Exception ex)          {            throw ex;          }        }        else        {          try          {            fileWorkbook = new XSSFWorkbook(fs);          }          catch          {            fileWorkbook = new HSSFWorkbook(fs);          }        }      }      for (int i = 0; i < fileWorkbook.NumberOfSheets; i++)      {        if (sheetIndex != null && sheetIndex != i)          continue;        DataTable dt = new DataTable();        ISheet sheet = fileWorkbook.GetSheetAt(i);        //表頭        IRow header = sheet.GetRow(sheet.FirstRowNum);        List<int> columns = new List<int>();        for (int j = 0; j < header.LastCellNum; j++)        {          object obj = GetValueTypeForXLS(header.GetCell(j) as HSSFCell);          if (obj == null || obj.ToString() == string.Empty)          {            dt.Columns.Add(new DataColumn("Columns" + j.ToString()));          }          else            dt.Columns.Add(new DataColumn(obj.ToString()));          columns.Add(j);        }        //數(shù)據(jù)        IEnumerator rows = sheet.GetEnumerator();        while (rows.MoveNext())        {          int j = sheet.FirstRowNum + 1;          DataRow dr = dt.NewRow();          bool hasValue = false;          foreach (int K in columns)          {            dr[K] = GetValueTypeForXLS(sheet.GetRow(K).GetCell(K) as HSSFCell);            if (dr[K] != null && dr[K].ToString() != string.Empty)            {              hasValue = true;            }          }          if (hasValue)          {            dt.Rows.Add(dr);          }          j++;        }        ds.Tables.Add(dt);      }      return ds;    }    /// <summary>    /// 根據(jù)DataTable導(dǎo)出Excel    /// </summary>    /// <param name="dt">DataTable</param>    /// <param name="file">保存地址</param>    public static void GetExcelByDataTable(DataTable dt, string file)    {      DataSet ds = new DataSet();      ds.Tables.Add(dt);      GetExcelByDataSet(ds, file);    }    /// <summary>    /// 根據(jù)DataSet導(dǎo)出Excel    /// </summary>    /// <param name="ds">DataSet</param>    /// <param name="file">保存地址</param>    public static void GetExcelByDataSet(DataSet ds, string file)    {      IWorkbook fileWorkbook = new HSSFWorkbook();      int index = 0;      foreach (DataTable dt in ds.Tables)      {        index++;        ISheet sheet = fileWorkbook.CreateSheet("Sheet" + index);        //表頭        IRow row = sheet.CreateRow(0);        for (int i = 0; i < dt.Columns.Count; i++)        {          ICell cell = row.CreateCell(i);          cell.SetCellValue(dt.Columns[i].ColumnName);        }        //數(shù)據(jù)        for (int i = 0; i < dt.Rows.Count; i++)        {          IRow row1 = sheet.CreateRow(i + 1);          for (int j = 0; j < dt.Columns.Count; j++)          {            ICell cell = row1.CreateCell(j);            cell.SetCellValue(dt.Rows[i][j].ToString());          }        }      }      //轉(zhuǎn)為字節(jié)數(shù)組      MemoryStream stream = new MemoryStream();      fileWorkbook.Write(stream);      var buf = stream.ToArray();      //保存為Excel文件      using (FileStream fs = new FileStream(file, FileMode.Create, FileAccess.Write))      {        fs.Write(buf, 0, buf.Length);        fs.Flush();      }    }    /// <summary>    /// 根據(jù)單元格將內(nèi)容返回為對(duì)應(yīng)類型的數(shù)據(jù)    /// </summary>    /// <param name="cell">單元格</param>    /// <returns>數(shù)據(jù)</returns>    private static object GetValueTypeForXLS(HSSFCell cell)    {      if (cell == null)        return null;      switch (cell.CellType)      {        case CellType.Blank: //BLANK:          return null;        case CellType.Boolean: //BOOLEAN:          return cell.BooleanCellValue;        case CellType.Numeric: //NUMERIC:          return cell.NumericCellValue;        case CellType.String: //STRING:          return cell.StringCellValue;        case CellType.Error: //ERROR:          return cell.ErrorCellValue;        case CellType.Formula: //FORMULA:        default:          return "=" + cell.CellFormula;      }    }  }

這里面可以有一些有意思的操作,比如版本兼容問題。這里通過多態(tài)很好的實(shí)現(xiàn)了兼容,但是如果是2007版本的xlsm被修改為xsl的后綴怎么辦呢,或者2003版本的被修改為xlsm后綴怎么辦呢。2003版本改為xlsm還是可以將其視為xls來處理的,但是2007改為xls就不行了。這時(shí)候可以強(qiáng)行修改文件的后綴名再打開。

但是上面的代碼沒有實(shí)現(xiàn)這個(gè)功能,兩個(gè)原因:一、這樣做不是很安全。二、這時(shí)候需要修改系統(tǒng)中其它地方此文件的文件名,放在類中實(shí)現(xiàn)不是很方便。

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 东源县| 和田市| 宜昌市| 柳河县| 临澧县| 屏东市| 阳原县| 洱源县| 河津市| 小金县| 凤山县| 曲周县| 若羌县| 宝坻区| 日土县| 龙山县| 东乌| 富锦市| 玉溪市| 山阴县| 德化县| 宜章县| 巴中市| 凤庆县| 岳普湖县| 衡南县| 义马市| 北安市| 隆林| 蒙山县| 扶沟县| 南乐县| 江源县| 于田县| 龙岩市| 汉寿县| 江油市| 永登县| 吐鲁番市| 定边县| 赤峰市|