亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

C#通過NPOI操作Excel的實例代碼

2019-10-29 21:16:03
字體:
來源:轉載
供稿:網友

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

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

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

npoi操作excel,c#,excel,npoi

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

public class ExcelHelper  {    /// <summary>    /// 根據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>    /// 根據Excel返回DataSet    /// </summary>    /// <param name="filePath">Excel文件地址</param>    /// <param name="sheetIndex">Sheet索引,可選,默認返回所有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);        }        //數據        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>    /// 根據DataTable導出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>    /// 根據DataSet導出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);        }        //數據        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());          }        }      }      //轉為字節數組      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>    /// 根據單元格將內容返回為對應類型的數據    /// </summary>    /// <param name="cell">單元格</param>    /// <returns>數據</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;      }    }  }

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

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到c#教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
九九热99久久久国产盗摄| 丝袜亚洲另类欧美重口| 成人羞羞国产免费| 日韩美女激情视频| 97久久精品国产| 国产一区二区丝袜高跟鞋图片| 日韩精品视频在线观看免费| 一本大道香蕉久在线播放29| 色婷婷av一区二区三区久久| 欧美精品免费在线观看| 一本一本久久a久久精品综合小说| 亚洲日本欧美日韩高观看| 亚洲色图色老头| 亚洲电影第1页| 午夜免费在线观看精品视频| 亚洲精品久久久久久久久久久| 欧美男插女视频| 69久久夜色精品国产7777| 日韩成人av网址| 成人激情视频小说免费下载| 午夜精品福利在线观看| 欧美激情精品在线| 亚洲qvod图片区电影| 国产91精品黑色丝袜高跟鞋| 九九热在线精品视频| 色一区av在线| 久久亚洲精品视频| 欧美日韩在线视频观看| 久久久久久12| 久热精品在线视频| 国产欧美一区二区三区在线看| 国产精品一区久久久| 亚洲欧美中文另类| 亚洲一区www| 美日韩精品免费视频| 97在线免费观看视频| 欧洲精品在线视频| 久久精品国产精品| 亚洲国产日韩欧美综合久久| 国产成人a亚洲精品| 国产精品久久久久久久久久尿| 成人午夜在线视频一区| 国产做受69高潮| 在线成人免费网站| 久久艹在线视频| 亚洲一二在线观看| 国产精品扒开腿做爽爽爽男男| 国产精品旅馆在线| 欧美国产乱视频| 日韩中文字幕第一页| 777精品视频| 欧美国产激情18| 欧美成人三级视频网站| 91色精品视频在线| www.亚洲成人| 亚洲视频精品在线| 精品久久香蕉国产线看观看gif| 日韩在线视频一区| 国外日韩电影在线观看| 国内精品久久久久久| 色噜噜久久综合伊人一本| 在线视频亚洲欧美| 国产精品看片资源| 最近2019中文字幕第三页视频| 91精品视频在线播放| 免费99精品国产自在在线| 国产一区二区三区三区在线观看| 这里只有精品视频| 久久综合久久88| 国产精品美女在线观看| 亚洲福利视频二区| 伊人激情综合网| 欧美成人亚洲成人| 日韩中文字幕在线视频播放| 久久久综合免费视频| 青草青草久热精品视频在线观看| 亚洲国产另类久久精品| 亚洲福利视频在线| 成人黄色影片在线| 亚洲福利在线播放| 亚洲精品视频久久| 最新日韩中文字幕| 国产在线视频一区| 国产亚洲视频在线| 国产区精品在线观看| 亚洲美女福利视频网站| 欧美电影在线观看| 亚洲片av在线| 深夜精品寂寞黄网站在线观看| 免费97视频在线精品国自产拍| 亚洲精品久久久久中文字幕二区| 亚洲精品小视频在线观看| 午夜精品免费视频| 国产午夜精品一区理论片飘花| 亚洲最新视频在线| 欧美贵妇videos办公室| 夜夜嗨av一区二区三区四区| 国产精品免费一区二区三区都可以| 97在线视频免费观看| 欧美成人手机在线| 日韩经典中文字幕在线观看| 日韩精品在线观看视频| 欧美午夜激情在线| 日韩av在线影院| 国内精品视频在线| 亚洲字幕一区二区| 中文字幕亚洲欧美一区二区三区| 69久久夜色精品国产69| 97视频免费在线观看| 亚洲另类欧美自拍| 日本国产高清不卡| 日韩成人激情在线| 26uuu另类亚洲欧美日本老年| 亚洲一区二区三区xxx视频| 亚洲免费视频在线观看| 欧美另类高清videos| 亚洲天堂影视av| 久久久久久久久久av| 日韩视频第一页| 欧美精品videos性欧美| 久久男人av资源网站| 色偷偷偷综合中文字幕;dd| 亚洲xxxx18| 欧美男插女视频| 亚洲午夜久久久影院| 亚洲欧洲美洲在线综合| 国产在线观看精品| 一个人看的www久久| 97av在线视频免费播放| 亚洲第一视频网| 欧美亚洲在线播放| 国产日韩中文字幕在线| 成人在线精品视频| 国产成人自拍视频在线观看| 日韩久久免费电影| 精品久久久久久亚洲国产300| 久久欧美在线电影| 国产成人avxxxxx在线看| 欧美成人三级视频网站| 亚洲视频专区在线| 伊人伊成久久人综合网小说| 激情懂色av一区av二区av| 午夜精品福利在线观看| 国产一区玩具在线观看| 欧美大人香蕉在线| 日韩亚洲在线观看| 欧美在线不卡区| 欧美在线观看视频| 91最新在线免费观看| 92看片淫黄大片看国产片| 亚洲国产欧美一区二区丝袜黑人| 国产精品一区二区三区在线播放| 米奇精品一区二区三区在线观看| 亚洲精品小视频| 91精品久久久久久久久久久| 日韩在线观看你懂的| 中国人与牲禽动交精品| 亚洲国产精品久久久久久| 欧美在线视频a| 亚洲国产精品va在线| 久久伊人精品一区二区三区| 91豆花精品一区| 欧美激情乱人伦| 伊人男人综合视频网|