EPPlus.Core 處理 Excel 報錯之天坑 WPS

来源:https://www.cnblogs.com/meowv/archive/2019/08/21/11387588.html
-Advertisement-
Play Games

最近工作中常常有有數據處理的需求,一個Excel動不動就是上十萬的數據量,在用 EPPlus.Core 導入數據入庫的時候遇到了一個莫名其妙的問題 我TM一個導入Excel,解析數據哪裡來的 dictionary??? 然後開始了艱辛的調試debug之旅,反覆上傳導入都不行,然後自己創建了一個格式相 ...


最近工作中常常有有數據處理的需求,一個Excel動不動就是上十萬的數據量,在用 EPPlus.Core 導入數據入庫的時候遇到了一個莫名其妙的問題 The given key 'rId2' was not present in the dictionary.

我TM一個導入Excel,解析數據哪裡來的 dictionary???

然後開始了艱辛的調試debug之旅,反覆上傳導入都不行,然後自己創建了一個格式相同數據量比較少的Excel文件上傳,成功。

這時候我大概知道是什麼問題了,給Excel數據的同事用的是WPS(這輩子都不會用的東東...),由於EPPlus對WPS支持度不怎麼友好,所以導致解析數據的時候出錯,將WPS保存的Excel文件用Office Excel打開另存為一個新的文件,再上傳解析,成功。

public async Task<ActionOutput> ProcessExcelData(IFormFile ExcelFile)
{
    using (var package = new ExcelPackage(ExcelFile.OpenReadStream()))
    {
        var sheet = package.Workbook.Worksheets.First();

        ...

        return new ActionOutput();
    }
}

切記:遠離WPS,遠離996..


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

-Advertisement-
Play Games
更多相關文章
  • 場景: 由一次大的項目改動引起的app端api不相容問題,這時候就需要對api做版本控制了,權衡之後因為用戶不多,選擇了強更,沒人想在已經寫了8000行代碼的單個svc文件中維護好幾個版本的介面或者繼續新建svc(wcf配置較繁瑣),但暴露出的版本控制問題還是要解決的,不能每次都強更呀。 api版本 ...
  • .NET Core 3.0 預覽版發佈已經好些時日了,博客園也已將其用於生產環境中,可見 .NET Core 日趨成熟 回歸正題,你想蓋大樓嗎?想 GitHub 首頁一片綠嗎?今天拿她玩玩自動提交代碼至 GitHub。 安裝項目模板 創建項目 直接使用 .NET CLI 創建一個 Work Serv ...
  • 以前的測試的時候使用正常,當輸入數據無效時,行標題上會出現紅色感嘆號的圓形圖標,最近拿起來適當修改完善了一下,發現ErrorText屬性的設置失效了,行標題上死活都不出現紅色感嘆號的圓形圖標,奇了怪了,怎麼回事,搜遍全網(包括官網),沒找到解決方案。 我就不信這個鞋,幸好有備份的之前的版本,拿過來和 ...
  • //獲取日期+時間 DateTime.Now.ToString(); // 2008-9-4 20:02:10 DateTime.Now.ToLocalTime().ToString(); // 2008-9-4 20:12:12 //獲取日期 DateTime.Now.ToLongDateStri... ...
  • C# 中的委托(Delegate)類似於 C 或 C++ 中函數的指針。委托(Delegate) 是存有對某個方法的引用的一種引用類型變數。引用可在運行時被改變。 委托(Delegate)特別用於實現事件和回調方法。所有的委托(Delegate)都派生自 System.Delegate 類。 委托多 ...
  • 大漠插件:3.1233 找圖,找色,識字,找字,視窗,按滑鼠,按鍵盤 0、註冊dm.dll; regsvr32 xxx\dm.dll 1、添加com引用; 2、dmsoft各種調用; 原理: 查找視窗hwnd→視窗激活→添加消息到文本框→回車→視窗取消激活 截圖: 代碼: ...
  • 不多說,直接上代碼 web.config如下 其中 SymmetricMethod.Decrypto 解密演算法,至於加解密演算法,大家自行百度吧 ...
  • 在使用vs2019添加mvc控制器的時候 這已經是第二次遇到這個問題了。常言道,多喝熱水,重啟試試。有時候當應用工作不正常,重啟也許能解決問題。但是程式員通常接觸不到伺服器系統許可權。而運維人員和公司流程經常人為製造麻煩阻止我們去重啟應用。 上一次就是通過重啟解決的。 翻牆找了很多解決方案,好似VS團 ...
一周排行
    -Advertisement-
    Play Games
  • 概述:本文代碼示例演示瞭如何在WPF中使用LiveCharts庫創建動態條形圖。通過創建數據模型、ViewModel和在XAML中使用`CartesianChart`控制項,你可以輕鬆實現圖表的數據綁定和動態更新。我將通過清晰的步驟指南包括詳細的中文註釋,幫助你快速理解並應用這一功能。 先上效果: 在 ...
  • openGauss(GaussDB ) openGauss是一款全面友好開放,攜手伙伴共同打造的企業級開源關係型資料庫。openGauss採用木蘭寬鬆許可證v2發行,提供面向多核架構的極致性能、全鏈路的業務、數據安全、基於AI的調優和高效運維的能力。openGauss深度融合華為在資料庫領域多年的研 ...
  • openGauss(GaussDB ) openGauss是一款全面友好開放,攜手伙伴共同打造的企業級開源關係型資料庫。openGauss採用木蘭寬鬆許可證v2發行,提供面向多核架構的極致性能、全鏈路的業務、數據安全、基於AI的調優和高效運維的能力。openGauss深度融合華為在資料庫領域多年的研 ...
  • 概述:本示例演示了在WPF應用程式中實現多語言支持的詳細步驟。通過資源字典和數據綁定,以及使用語言管理器類,應用程式能夠在運行時動態切換語言。這種方法使得多語言支持更加靈活,便於維護,同時提供清晰的代碼結構。 在WPF中實現多語言的一種常見方法是使用資源字典和數據綁定。以下是一個詳細的步驟和示例源代 ...
  • 描述(做一個簡單的記錄): 事件(event)的本質是一個委托;(聲明一個事件: public event TestDelegate eventTest;) 委托(delegate)可以理解為一個符合某種簽名的方法類型;比如:TestDelegate委托的返回數據類型為string,參數為 int和 ...
  • 1、AOT適合場景 Aot適合工具類型的項目使用,優點禁止反編 ,第一次啟動快,業務型項目或者反射多的項目不適合用AOT AOT更新記錄: 實實在在經過實踐的AOT ORM 5.1.4.117 +支持AOT 5.1.4.123 +支持CodeFirst和非同步方法 5.1.4.129-preview1 ...
  • 總說周知,UWP 是運行在沙盒裡面的,所有許可權都有嚴格限制,和沙盒外交互也需要特殊的通道,所以從根本杜絕了 UWP 毒瘤的存在。但是實際上 UWP 只是一個應用模型,本身是沒有什麼許可權管理的,許可權管理全靠 App Container 沙盒控制,如果我們脫離了這個沙盒,UWP 就會放飛自我了。那麼有沒... ...
  • 目錄條款17:讓介面容易被正確使用,不易被誤用(Make interfaces easy to use correctly and hard to use incorrectly)限制類型和值規定能做和不能做的事提供行為一致的介面條款19:設計class猶如設計type(Treat class de ...
  • title: 從零開始:Django項目的創建與配置指南 date: 2024/5/2 18:29:33 updated: 2024/5/2 18:29:33 categories: 後端開發 tags: Django WebDev Python ORM Security Deployment Op ...
  • 1、BOM對象 BOM:Broswer object model,即瀏覽器提供我們開發者在javascript用於操作瀏覽器的對象。 1.1、window對象 視窗方法 // BOM Browser object model 瀏覽器對象模型 // js中最大的一個對象.整個瀏覽器視窗出現的所有東西都 ...