asp.net 使用NPOI讀取excel文件

来源:https://www.cnblogs.com/laoq112/archive/2019/11/21/11903684.html
-Advertisement-
Play Games

asp.net 使用NPOI讀取excel文件內容 NPOI下載地址:NPOI public class ExcelHelper { /// <summary> /// 讀取Excel文件數據到DataSet,一個Sheet對應一個DataTable /// </summary> /// <para ...


asp.net 使用NPOI讀取excel文件內容

NPOI下載地址:NPOI

public class ExcelHelper
{
    /// <summary>
    /// 讀取Excel文件數據到DataSet,一個Sheet對應一個DataTable
    /// </summary>
    /// <param name="strExcelFilePath">Excel文件的物理路徑</param>
    /// <returns></returns>
    public static DataSet GetDataFromExcel(string strExcelPhysicalPath, out string strError)
    {
        try
        {
            DataSet dsResult = new DataSet();
            strError = "";

            IWorkbook wbook = null;
            using (FileStream fs = new FileStream(strExcelPhysicalPath, FileMode.Open, FileAccess.Read))
            {
                if (strExcelPhysicalPath.IndexOf(".xlsx") > 0)
                {
                    wbook = new XSSFWorkbook(fs);
                }
                else
                {
                    wbook = new HSSFWorkbook(fs);
                }
            }

            for (int i = 0; i < wbook.NumberOfSheets; i++)
            {
                ISheet wsheet = wbook.GetSheetAt(i);
                if (wsheet == null) continue;

                DataTable dtSheet = GetDataFromSheet(wsheet, out strError);
                if (dtSheet != null)
                {
                    dtSheet.TableName = wsheet.SheetName.Trim();
                    dsResult.Tables.Add(dtSheet);
                }
                else
                {
                    dsResult = null;
                    break;
                }
            }
            return dsResult;
        }
        catch (Exception ex)
        {
            strError = ex.Message.ToString();
            return null;
        }
    }

    private static DataTable GetDataFromSheet(ISheet wsheet, out string strError)
    {
        try
        {
            DataTable dtResult = new DataTable();
            strError = "";

            //取sheet最大列數
            int max_column = 0;
            for (int i = wsheet.FirstRowNum; i <= wsheet.LastRowNum; i++)
            {
                IRow rsheet = wsheet.GetRow(i);
                if (rsheet != null && rsheet.LastCellNum > max_column)
                {
                    max_column = rsheet.LastCellNum;
                }
            }
            //給DataTable添加列
            for (int i = 0; i < max_column; i++)
            {
                dtResult.Columns.Add("A" + i.ToString());
            }

            for (int i = wsheet.FirstRowNum; i <= wsheet.LastRowNum; i++)
            {
                DataRow dRow = dtResult.NewRow();
                IRow rsheet = wsheet.GetRow(i);

                if (rsheet == null) continue;

                for (int j = rsheet.FirstCellNum; j < rsheet.LastCellNum; j++)
                {
                    ICell csheet = rsheet.GetCell(j);

                    if (csheet == null) continue;

                    switch (csheet.CellType)
                    {
                        case CellType.Blank:
                            dRow[j] = "";
                            break;
                        case CellType.Boolean:
                            dRow[j] = csheet.BooleanCellValue;
                            break;
                        case CellType.Error:
                            dRow[j] = csheet.ErrorCellValue;
                            break;
                        case CellType.Formula:
                            try
                            {
                                dRow[j] = csheet.NumericCellValue;

                                short format1 = csheet.CellStyle.DataFormat;
                                if (format1 == 177 || format1 == 178 || format1 == 188)
                                {
                                    dRow[j] = csheet.NumericCellValue.ToString("#0.00");
                                }
                            }
                            catch
                            {
                                dRow[j] = csheet.StringCellValue.Trim();
                            }
                            break;
                        case CellType.Numeric:
                            try
                            {
                                short format2 = csheet.CellStyle.DataFormat;
                                if (format2 == 14 || format2 == 31 || format2 == 57 || format2 == 58)
                                {
                                    dRow[j] = csheet.DateCellValue;
                                }
                                else
                                {
                                    dRow[j] = csheet.NumericCellValue;
                                }
                                if (format2 == 177 || format2 == 178 || format2 == 188)
                                {
                                    dRow[j] = csheet.NumericCellValue.ToString("#0.00");
                                }
                            }
                            catch
                            {
                                dRow[j] = csheet.StringCellValue.Trim();
                            }
                            break;
                        case CellType.String:
                            dRow[j] = csheet.StringCellValue.Trim();
                            break;
                        default:
                            dRow[j] = csheet.StringCellValue.Trim();
                            break;
                    }
                }

                dtResult.Rows.Add(dRow);
            }
            return dtResult;
        }
        catch (Exception ex)
        {
            strError = ex.Message.ToString();
            return null;
        }
    }
}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 首先,小編要告訴大家一個殘酷的現實,那就是layui對按鈕沒有提供點擊事件的支持… 這裡的點擊事件是指單純的點擊事件,而不是提交事件,或者是數據表格中內嵌的button,對於這兩者,layui是有lay-submit和lay-event這個屬性進行支持的,所以這裡只能使用最原始的js和jq進行監聽點 ...
  • 本文梯子 前言 1、.net core 框架性能測試 2、.net core 執行過程 3、中間件執行過程 4、AOP切麵 5、整體框架結構與資料庫表UML 一、創建第一個Core 1、SDK 安裝 2、新建項目 2、新建項目(3.0SDK) 3、項目整體結構分析 二、重要文件說明 1、Progra ...
  • //接收的為空時,則表示客戶端下線,跳出迴圈 if (r == 0) { break; }; string str = Encoding.UTF8.GetString(buffer, 0, r); //RemoteEndPoint:可以得到遠程客戶端的IP和埠號。 ShowMsg(socketSe... ...
  • static void CopyFiles() { string sourceDir = @"D:\C\ll"; string destDir = @"D:\LL"; if (!Directory.Exists(destDir)) { Directo... ...
  • //加密 public static string GDEncode(string data, string Key) { Key = "12345678"; byte[] byKey = System.Text.ASCIIEncoding.ASCII.GetBytes(Key); byte[] b ...
  • 當我們的系統時間不正常,比如設置一個日期-1999年9月9日,會引發證書問題。 系統時間不正常-IE有概率能訪問 觸發NavigateError事件,異常代碼INET_E_INVALID_CERTIFICATE -- 這是一個必要不充分條件,系統時間不正常時IE有相關證書異常,更新時間能解決此類異常 ...
  • asp.net 使用 Application 限制單一登錄 原理:用戶登錄後系統會分配一個與用戶唯一對應的SessionID,將當前用戶ID與其SessionID對應保存在Application中,一旦該用戶在其他地方重覆登錄則Application中保存的SessionID就會被更新,導致當前se ...
  • 場景 使用Visual Studio 開發Winform程式,使用SVN進行項目版本管理。 在添加引用時,會出現在A電腦中添加了絕對路徑的引用,在B電腦中就會出現找不到 並且將此引用標識為?的狀態。 註: 博客主頁: https://blog.csdn.net/badao_liumang_qizhi ...
一周排行
    -Advertisement-
    Play Games
  • JWT(JSON Web Token)是一種用於在網路應用之間傳遞信息的開放標準(RFC 7519)。它使用 JSON 對象在安全可靠的方式下傳遞信息,通常用於身份驗證和信息交換。 在Web API中,JWT通常用於對用戶進行身份驗證和授權。當用戶登錄成功後,伺服器會生成一個Token並返回給客戶端 ...
  • 老周在幾個世紀前曾寫過樹莓派相關的 iOT 水文,之所以沒寫 Nano Framework 相關的內容,是因為那時候這貨還不成熟,可玩性不高。不過,這貨現在已經相對完善,老周都把它用在項目上了——第一個是自製的智能插座,這個某寶上50多塊可以買到,搜“esp32 插座”就能找到。一種是 86 型盒子 ...
  • 引言 上一篇我們創建了一個Sample.Api項目和Sample.Repository,並且帶大家熟悉了一下Moq的概念,這一章我們來實戰一下在xUnit項目使用依賴註入。 Xunit.DependencyInjection Xunit.DependencyInjection 是一個用於 xUnit ...
  • 在 Avalonia 中,樣式是定義控制項外觀的一種方式,而控制項主題則是一組樣式和資源,用於定義應用程式的整體外觀和感覺。本文將深入探討這些概念,並提供示例代碼以幫助您更好地理解它們。 樣式是什麼? 樣式是一組屬性,用於定義控制項的外觀。它們可以包括背景色、邊框、字體樣式等。在 Avalonia 中,樣 ...
  • 在處理大型Excel工作簿時,有時候我們需要在工作表中凍結窗格,這樣可以在滾動查看數據的同時保持某些行或列固定不動。凍結窗格可以幫助我們更容易地導航和理解複雜的數據集。相反,當你不需要凍結窗格時,你可能需要解凍它們以獲得完整的視野。 下麵將介紹如何使用免費.NET庫通過C#實現凍結Excel視窗以鎖 ...
  • .NET 部署 IIS 的簡單步驟一: 下載 dotnet-hosting-x.y.z-win.exe ,下載地址:.NET Downloads (Linux, macOS, and Windows) (microsoft.com) .NET 部署 IIS 的簡單步驟二: 選擇對應的版本,點擊進入詳 ...
  • 拓展閱讀 資料庫設計工具-08-概覽 資料庫設計工具-08-powerdesigner 資料庫設計工具-09-mysql workbench 資料庫設計工具-10-dbdesign 資料庫設計工具-11-dbeaver 資料庫設計工具-12-pgmodeler 資料庫設計工具-13-erdplus ...
  • 初識STL STL,(Standard Template Library),即"標準模板庫",由惠普實驗室開發,STL中提供了非常多對信息學奧賽很有用的東西。 vector vetor是STL中的一個容器,可以看作一個不定長的數組,其基本形式為: vector<數據類型> 名字; 如: vector ...
  • 前言 最近自己做了個 Falsk 小項目,在部署上伺服器的時候,發現雖然不乏相關教程,但大多都是將自己項目代碼複製出來,不講核心邏輯,不太簡潔,於是將自己部署的經驗寫成內容分享出來。 uWSGI 簡介 uWSGI: 一種實現了多種協議(包括 uwsgi、http)並能提供伺服器搭建功能的 Pytho ...
  • 1 文本Embedding 將整個文本轉化為實數向量的技術。 Embedding優點是可將離散的詞語或句子轉化為連續的向量,就可用數學方法來處理詞語或句子,捕捉到文本的語義信息,文本和文本的關係信息。 ◉ 優質的Embedding通常會讓語義相似的文本在空間中彼此接近 ◉ 優質的Embedding相 ...