使用NPOI處理EXCEL文件:例1-關于優化的一些問題

記得有一次處理Excel文件對比,自己前后使用VBA和NPOI對比了下效率。由于涉及到頁面的渲染和刷新,二者的處理速度差了個數量級(10多秒和幾十分鐘的差別)。當然使用NPOI操作時也做了一定優化。印象這么深刻這次一有需求就想到了NPOI。

需求:財務數據,只挑出最新月份(整數類型,yyyyMM)的數據。然后將數據增加一部分固定列內容按格式寫入到另外一張表中。

由于宋丹丹老師把一切復雜的問題都總結為三步:打開冰箱門,把大象塞進去,關上冰箱門。那么我也把這個問題拆分出以下幾個三步走

1、打開數據源:

使用NPOI可以打開xls和xlsx類型的,這個沒有一點問題

由于使用了wpf,下面也又分為(以下沒有什么好說的都是正常代碼)

????????1.1 設置一個按鈕

????????1.2 點擊時彈出“打開文件”框

????????1.3如果選擇了文件就獲取文件路徑。

2、讀取數據:

上面獲取了文件路徑,我們就可以正常打開了。

對于如何讀取到合適的數據,我在這里有個優化

先只讀取日期列,找出最大日期的那些行。這里我用了一個Dictionary<DateTime, List<int>> 來保存行號。同時記錄了一個最大的日期值。通過這點只讀取了日期最大的行,會減少讀取操作。我覺得這一點

 ISheet sheet = workbook.GetSheetAt(0);int cellcount = head.LastCellNum;//一行最多有多少個列long maxRow = sheet.LastRowNum;//頁面有多少行Dictionary<DateTime, List<int>> dateRows = new Dictionary<DateTime, List<int>>();var rows = new List<IRow>();for (int i = 1; i < maxRow; i++)//第一行是標題行,忽略{var row = sheet.GetRow(i);var cell = row.GetCell(0);//日期行,數據形式yyyyMMif (cell != null){var num=(int) cell.NumericCellValue;var year = num / 100;var mon = num% 100;var day = 1;var date = new DateTime(year, mon, day);if (dateRows.Keys.Contains(date)){dateRows[date].Add(i);}else{dateRows.Add(date, new List<int> { i });}}}

3、寫入并保存文件:

由于單元格有一定格式,我想了一個取巧的辦法-使用一個文件模板,保存的時候另存文件。

在數據寫入的時候又發現了一個優化點。有20多行他們之前是可以采用循環來賦值的。

 //表1的第10行到34,對應表2的第18到42行,數據格式也一致,完美。for (int j = 9, k = 17; j < 34; j++, k++){if (srcRow.Cells[j].CellType == CellType.Numeric){row.CreateCell(k).SetCellValue(srcRow.Cells[j].NumericCellValue);}}

自我總結:一個簡單的程序,自頂向下的思路,逐步解決問題。優化要多碼,多總結。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/161415.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/161415.shtml
英文地址,請注明出處:http://en.pswp.cn/news/161415.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

千云物流 - 使用k8s負載均衡openelb

openelb的介紹 具體根據官方文檔進行安裝官方文檔,這里作為測試環境的安裝使用. OpenELB 是一個開源的云原生負載均衡器實現,可以在基于裸金屬服務器、邊緣以及虛擬化的 Kubernetes 環境中使用 LoadBalancer 類型的 Service 對外暴露服務。OpenELB 項目最初由 KubeSphere 社區…

redis的性能管理及集群架構(主從復制、哨兵模式)

一、redis的性能管理 1、內存指標info memory 內存指標&#xff08;重要&#xff09; used_memory:853736 數據占用的內存 used_memory_rss:10551296 redis向操作系統申請的內存 used_memory_peak:853736 redis使用內存的峰值 注&#xff1a;單位&#xff1a;字節 系…

策略模式應用(內窺鏡項目播放不同種類的視頻)

新舊代碼對比 策略模式 基本概念 策略模式是一種行為設計模式&#xff0c;它定義了一系列算法&#xff0c;將每個算法封裝起來&#xff0c;并且使它們可以互相替換。策略模式允許客戶端選擇算法的具體實現&#xff0c;而不必改變客戶端的代碼。這樣&#xff0c;客戶端代碼就…

中國區域250米歸一化植被指數數據集(2000-2022)

中國區域250米歸一化植被指數數據集(2000-2022)數據集是中國區域2000至2022年月度歸一化植被指數產品&#xff0c;空間分辨率250米&#xff0c;合成方式采用月最大值合成&#xff0c;每年12期&#xff0c;共275期。本產品是基于Aqua/Terra-MODIS衛星傳感器MOD13Q1產品以及土地利…

寄存器、緩存、內存之間的關系和區別

https://blog.csdn.net/m0_46761060/article/details/124689209 目錄 關系1、寄存器2、緩存&#xff08;Cache&#xff09; 2.1、寄存器和緩存的區別2.2、一級緩存和二級緩存3、內存 3.1、只讀存儲器 ROM&#xff08;Read Only Memory&#xff09;3.2、隨機存儲器 RAM&#xf…

基于LLM+場景識別+詞槽實體抽取實現多輪問答

前言 隨著人工智能技術的不斷進步&#xff0c;大語言模型&#xff08;LLM&#xff09;已成為技術前沿的熱點。它們不僅能夠理解和生成文本&#xff0c;還能在多種應用場景中實現復雜的交互。本文將深入探討一段結合了大語言模型能力、意圖識別和詞槽實體抽取的Python代碼&…

鏈表OJ--上

文章目錄 前言一、反轉鏈表二、移除鏈表元素三、鏈表中倒數第K個結點四、相交鏈表五、鏈表的中間結點 前言 一、反轉鏈表 力扣206&#xff1a;反轉鏈表- - -點擊此處傳送 思路圖&#xff1a; 方法一&#xff1a;改變指向 方法二&#xff1a; 代碼&#xff1a; //方法一 /…

十一、h.264編碼

前言 測試環境&#xff1a; ffmpeg的4.3.2自行編譯版本windows環境qt5.12 使用H.264編碼對YUV視頻進行壓縮 ffmpeg -s 640x480 -pix_fmt yuv420p -i in.yuv -c:v libx264 out.h264 -c:v libx264是指定使用libx264作為編碼器完整代碼&#xff1a; H264EncodeThread.h #ifnd…

用HALCON標定助手對相機進行標定

任務要求&#xff1a; 已知相機鏡頭焦距f為8mm&#xff0c;相機單個CCD像素在水平和豎直兩個方向上的尺寸均為3.75微米&#xff0c;相機為普通透光鏡頭和面陣相機&#xff0c;對相機進行標定&#xff0c;測量相機的內外參數。 操作步驟&#xff1a; 1. 在HALCON中運行gen_ca…

C#使用whisper.net實現語音識別(語音轉文本)

目錄 介紹 效果 輸出信息 項目 代碼 下載 介紹 github地址&#xff1a;https://github.com/sandrohanea/whisper.net Whisper.net. Speech to text made simple using Whisper Models 模型下載地址&#xff1a;https://huggingface.co/sandrohanea/whisper.net/tree…

Nginx高級

Nginx高級 第一部分&#xff1a;擴容 通過擴容提升整體吞吐量 1.單機垂直擴容&#xff1a;硬件資源增加 云服務資源增加 整機&#xff1a;IBM、浪潮、DELL、HP等 CPU/主板&#xff1a;更新到主流 網卡&#xff1a;10G/40G網卡 磁盤&#xff1a;SAS(SCSI) HDD&#xff08;機械…

如何使用ArcGIS Pro進行坐標轉換

不同來源的數據坐標系可能是不同的&#xff0c;為了統一使用這些數據就需要進行坐標轉換&#xff0c;ArcGIS Pro作為專業的GIS軟件&#xff0c;坐標轉換功能肯定也是包含的&#xff0c;這里為大家介紹一下ArcGIS Pro如何進行坐標轉換&#xff0c;希望能對你有所幫助。 數據來源…

【Exception】npm ERR! code UNABLE_TO_GET_ISSUER_CERT_LOCALLY

Talk is cheap, show me the code. 環境 | Environment kversionOSwindows 11nodev18.14.2npm9.5.0 報錯日志 | Error log >npm create vitelatest Need to install the following packages:create-vite5.0.0 Ok to proceed? (y) y npm ERR! code UNABLE_TO_GET_ISSUER_…

2023亞太杯數學建模B題思路+模型+代碼+論文

2023亞太地區數學建模A題思路&#xff1a;開賽后第一時間更新&#xff0c;獲取見文末 名片 2023亞太地區數學建模B題思路&#xff1a;開賽后第一時間更新&#xff0c;獲取見文末 名片 2023亞太地區數學建模C題思路&#xff1a;開賽后第一時間更新&#xff0c;獲取見文末 名片…

idea修改行號顏色

前言 i當idea用了深色主題后&#xff0c;發現行號根本看不清&#xff0c;或者很模糊 例如下面這樣 修改行號顏色 在IntelliJ IDEA中&#xff0c;你可以根據自己的喜好和需求定制行號的顏色。下面是修改行號顏色的步驟&#xff1a; 打開 IntelliJ IDEA。 轉到 “File”&…

ChatGPT規模化服務的經驗與教訓

2022年11月30日&#xff0c;OpenAI發布ChatGPT&#xff0c;以很多人未曾預料的速度迅速走紅。與此同時&#xff0c;由于短時間內用戶量的暴漲&#xff0c;導致服務器過載&#xff0c;迫使OpenAI停止新用戶的注冊。 ChatGPT發布這一年&#xff0c;同樣的情景發生了好幾次。在最近…

opencv-圖像金字塔

圖像金字塔是一種圖像處理技術&#xff0c;它通過不斷降低圖像的分辨率&#xff0c;形成一系列圖像。金字塔分為兩種類型&#xff1a;高斯金字塔和拉普拉斯金字塔。 高斯金字塔&#xff08;Gaussian Pyramid&#xff09;&#xff1a; 高斯金字塔是通過使用高斯濾波和降采樣&a…

專業遠程控制如何塑造安全體系?向日葵“全流程安全閉環”解析

安全是遠程控制的重中之重&#xff0c;作為國民級遠程控制品牌&#xff0c;向日葵遠程控制就極為注重安全遠控服務的塑造。近期向日葵發布了以安全和核心的新版“向日葵15”以及同步發布《貝銳向日葵遠控安全標準白皮書》&#xff08;下簡稱《白皮書》&#xff09;&#xff0c;…

使用微信小程序openMapApp接口,報錯問題解決openMapApp:fail invaild coord

使用微信小程序的 openMapApp 接口時遇到了坐標無效的錯誤 (openMapApp:fail invalid coord)。這個錯誤通常是由于提供的地理坐標不符合預期的格式或范圍而引起的&#xff1a; 坐標格式&#xff1a; 確保提供的坐標符合正確的格式。常見的格式是 "緯度,經度"&#xf…

【11月比賽合集】5場可報名的「創新應用」、「數據分析」和「程序設計」大獎賽,任君挑選!

CompHub[1] 實時聚合多平臺的數據類(Kaggle、天池…)和OJ類(Leetcode、牛客…&#xff09;比賽。本賬號會推送最新的比賽消息&#xff0c;歡迎關注&#xff01; 以下信息僅供參考&#xff0c;以比賽官網為準 目錄 創新應用賽&#xff08;1場比賽&#xff09;數據分析賽&#…