欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#使用NPOI實現(xiàn)Excel和DataTable的互轉(zhuǎn)

 更新時間:2022年02月21日 16:30:50   作者:林深時見祿  
這篇文章主要為大家詳細介紹了C#使用NPOI實現(xiàn)Excel和DataTable的互轉(zhuǎn),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

什么是NPOI?

NPOI是指構(gòu)建在POI 3.x版本之上的一個程序,NPOI可以在沒有安裝Office的情況下對Word或Excel文檔進行讀寫操作。

NPOI是一個開源的C#讀寫Excel、WORD等微軟OLE2組件文檔的項目。

使用NuGet安裝NPOI

NuGet直接搜索NPOI,目前版本是v2.4.1,將其安裝至項目即可。

安裝完成后,項目會自動為我們添加這4個引用

同時還需要在程序中引入NPOI.SS.UserModel;NPOI.XSSF.UserModel;NPOI.HSSF.UserModel;三個命名空間

廢話不多說,直接上代碼

DataTable導出Excel

/// <summary>
/// Datable導出成Excel
/// </summary>
/// <param name="dt"></param>
/// <param name="file">導出路徑(包括文件名與擴展名)</param>
public static void TableToExcel(DataTable dt, string file)
? ? ? ? {
? ? ? ? ? ? IWorkbook workbook;
? ? ? ? ? ? string fileExt = Path.GetExtension(file).ToLower();
? ? ? ? ? ? if (fileExt == ".xlsx") { workbook = new XSSFWorkbook(); } else if (fileExt == ".xls") { workbook = new HSSFWorkbook(); } else { workbook = null; }
? ? ? ? ? ? if (workbook == null) { return; }
? ? ? ? ? ? ISheet sheet = string.IsNullOrEmpty(dt.TableName) ? workbook.CreateSheet("Sheet1") : workbook.CreateSheet(dt.TableName);
?
? ? ? ? ? ? //表頭 ?
? ? ? ? ? ? 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();
? ? ? ? ? ? workbook.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();
? ? ? ? ? ? }
? ? ? ? }

Excel導入DataTable

/// <summary>
/// Excel導入成Datable
/// </summary>
/// <param name="file">導入路徑(包含文件名與擴展名)</param>
/// <returns></returns>
public static DataTable ExcelToTable(string file)
? ? ? ? {
? ? ? ? ? ? DataTable dt = new DataTable();
? ? ? ? ? ? IWorkbook workbook;
? ? ? ? ? ? string fileExt = Path.GetExtension(file).ToLower();
? ? ? ? ? ? using (FileStream fs = new FileStream(file, FileMode.Open, FileAccess.Read))
? ? ? ? ? ? {
? ? ? ? ? ? ? ? //XSSFWorkbook 適用XLSX格式,HSSFWorkbook 適用XLS格式
? ? ? ? ? ? ? ? if (fileExt == ".xlsx") { workbook = new XSSFWorkbook(fs); } else if (fileExt == ".xls") { workbook = new HSSFWorkbook(fs); } else { workbook = null; }
? ? ? ? ? ? ? ? if (workbook == null) { return null; }
? ? ? ? ? ? ? ? ISheet sheet = workbook.GetSheetAt(0);
?
? ? ? ? ? ? ? ? //表頭 ?
? ? ? ? ? ? ? ? IRow header = sheet.GetRow(sheet.FirstRowNum);
? ? ? ? ? ? ? ? List<int> columns = new List<int>();
? ? ? ? ? ? ? ? for (int i = 0; i < header.LastCellNum; i++)
? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? object obj = GetValueType(header.GetCell(i));
? ? ? ? ? ? ? ? ? ? if (obj == null || obj.ToString() == string.Empty)
? ? ? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? ? ? dt.Columns.Add(new DataColumn("Columns" + i.ToString()));
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? else
? ? ? ? ? ? ? ? ? ? ? ? dt.Columns.Add(new DataColumn(obj.ToString()));
? ? ? ? ? ? ? ? ? ? columns.Add(i);
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? //數(shù)據(jù) ?
? ? ? ? ? ? ? ? for (int i = sheet.FirstRowNum + 1; i <= sheet.LastRowNum; i++)
? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? DataRow dr = dt.NewRow();
? ? ? ? ? ? ? ? ? ? bool hasValue = false;
? ? ? ? ? ? ? ? ? ? foreach (int j in columns)
? ? ? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? ? ? dr[j] = GetValueType(sheet.GetRow(i).GetCell(j));
? ? ? ? ? ? ? ? ? ? ? ? if (dr[j] != null && dr[j].ToString() != string.Empty)
? ? ? ? ? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? ? ? ? ? hasValue = true;
? ? ? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? if (hasValue)
? ? ? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? ? ? dt.Rows.Add(dr);
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
? ? ? ? ? ? return dt;
? ? ? ? }
?
? ? ? ? /// <summary>
? ? ? ? /// 獲取單元格類型
? ? ? ? /// </summary>
? ? ? ? /// <param name="cell"></param>
? ? ? ? /// <returns></returns>
? ? ? ? private static object GetValueType(ICell 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;
? ? ? ? ? ? }
}

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • c# 多線程處理多個數(shù)據(jù)的方法

    c# 多線程處理多個數(shù)據(jù)的方法

    這篇文章主要介紹了c# 多線程處理多個數(shù)據(jù)的方法,幫助大家更好的理解和學習使用c#,感興趣的朋友可以了解下
    2021-03-03
  • C#多線程的ResetAbort()方法

    C#多線程的ResetAbort()方法

    這篇文章介紹了C#多線程的ResetAbort()方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-04-04
  • C#獲取并修改文件擴展名的方法

    C#獲取并修改文件擴展名的方法

    這篇文章主要介紹了C#獲取并修改文件擴展名的方法,實例分析了C#編程方式修改文件擴展名的技巧,涉及Path類的使用方法,需要的朋友可以參考下
    2015-04-04
  • C# Winform選項卡集成窗體詳解

    C# Winform選項卡集成窗體詳解

    這篇文章主要為大家詳細介紹了C# Winform選項卡集成窗體詳解的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • C#獲取文件夾及文件的大小與占用空間的方法

    C#獲取文件夾及文件的大小與占用空間的方法

    這篇文章主要介紹了C#獲取文件夾及文件的大小與占用空間的方法,需要的朋友可以參考下
    2014-07-07
  • C#把dll分別放在指定的文件夾的方法步驟

    C#把dll分別放在指定的文件夾的方法步驟

    本文主要介紹了C#把dll分別放在指定的文件夾的方法步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-05-05
  • 在C#中使用MSMQ的方法

    在C#中使用MSMQ的方法

    這篇文章主要介紹了在C#中使用MSMQ的方法,幫助大家更好的理解和使用c#,感興趣的朋友可以了解下
    2021-01-01
  • C#灰度化圖像的實例代碼

    C#灰度化圖像的實例代碼

    灰度化一幅圖像就是將圖像的色彩信息全部丟掉,將24位的位圖信息,用8位來表示,灰度圖共有256級灰度等級,也就是將24位位圖的一點如(255,255,255)轉(zhuǎn)換成255,所以R,G,B三個值所乘的系數(shù)和為1
    2013-09-09
  • C#如何動態(tài)設(shè)置屏幕分辨率

    C#如何動態(tài)設(shè)置屏幕分辨率

    這篇文章主要為大家詳細介紹了C#動態(tài)設(shè)置屏幕分辨率的方法,我們可以使用Screen類設(shè)置屏幕分辨率,感興趣的小伙伴們可以參考一下
    2016-04-04
  • C#中分部類和分部方法的應(yīng)用

    C#中分部類和分部方法的應(yīng)用

    本篇文章介紹了,C#中分部類和分部方法的應(yīng)用。需要的朋友參考下
    2013-04-04

最新評論