ASP.NET 開源導入導出庫Magicodes.IE 完成Excel圖片導入導出

来源:https://www.cnblogs.com/yyfh/archive/2020/03/18/12515229.html
-Advertisement-
Play Games

Magicodes.IE Excel圖片導入導出 為了更好的根據實際功能來迭代,從2.2的里程碑規劃開始,我們將結合社區的建議和意見來進行迭代,您可以點此鏈接來提交您的意見和建議: https://github.com/dotnetcore/Magicodes.IE/issues/46 說明 本章教 ...


Magicodes.IE Excel圖片導入導出

為了更好的根據實際功能來迭代,從2.2的里程碑規劃開始,我們將結合社區的建議和意見來進行迭代,您可以點此鏈接來提交您的意見和建議:
https://github.com/dotnetcore/Magicodes.IE/issues/46

說明

本章教程主要說明如何使用Magicodes.IE.Excel進行圖片的導入導出。

要點

  • 配置DTO進行Excel圖片導出
  • 配置DTO進行Excel圖片導入

圖片導入導出特性說明

ExportImageFieldAttribute

  • Height: 高度(預設15)
  • Width:寬度(預設50)
  • Alt:圖片不存在時替換文本

ImportImageFieldAttribute

  • ImageDirectory: 圖片存儲路徑(預設存儲到臨時目錄)
  • ImportImageTo:圖片導出方式(預設Base64),支持的方式如下所示:
    /// <summary>
    ///     圖片導入類型
    /// </summary>
    public enum ImportImageTo
    {
        /// <summary>
        ///     導入到臨時目錄
        /// </summary>
        TempFolder,

        /// <summary>
        ///     導入為base64格式
        /// </summary>
        Base64
    }

主要步驟

1.安裝包Magicodes.IE.Excel

Install-Package Magicodes.IE.Excel

2.使用Magicodes.IE.Excel導出圖片到Excel

如下述示例代碼所示,我們需要在圖片屬性上添加ExportImageFieldAttribute特性,使用特性的“Width”屬性指定圖片寬度,“Height”屬性指定圖片高度,“Alt”屬性指定替換文本,也就是當圖片不存在時則會顯示此文本:

   [ExcelExporter(Name = "測試")]
    public class ExportTestDataWithPicture
    {
        [ExporterHeader(DisplayName = "加粗文本", IsBold = true)]
        public string Text { get; set; }

        [ExporterHeader(DisplayName = "普通文本")] public string Text2 { get; set; }
        [ExporterHeader(DisplayName = "忽略", IsIgnore = true)]
        public string Text3 { get; set; }

        [ExportImageField(Width = 20, Height = 120)]
        [ExporterHeader(DisplayName = "圖1")]
        public string Img1 { get; set; }
        [ExporterHeader(DisplayName = "數值", Format = "#,##0")]
        public decimal Number { get; set; }
        [ExporterHeader(DisplayName = "名稱", IsAutoFit = true)]
        public string Name { get; set; }
        /// <summary>
        /// 時間測試
        /// </summary>
        [ExporterHeader(DisplayName = "日期1", Format = "yyyy-MM-dd")]
        public DateTime Time1 { get; set; }

        [ExportImageField(Width = 50, Height = 120, Alt = "404")]
        [ExporterHeader(DisplayName = "圖", IsAutoFit = false)]
        public string Img { get; set; }
    }

值得註意的是:

  • ExportImageFieldAttribute特性是必須的
  • 圖片屬性類型必須為string類型,支持本地圖片和遠程圖片地址

接下來,我們就可以使用API來執行導出了。其實除了Dto的不同,導出API還是一個,如下述代碼所示:

        public async Task ExportPicture_Test()
        {
            IExporter exporter = new ExcelExporter();
            var url = Path.Combine("TestFiles", "ExporterTest.png");
            for (var i = 0; i < data.Count; i++)
            {
                var item = data[i];
                item.Img1 = url;
                if (i == 4)
                    item.Img = null;
                else
                    item.Img = "https://docs.microsoft.com/en-us/media/microsoft-logo-dark.png";
            }
            var result = await exporter.Export(filePath, data);
        }

如上述代碼所示,目前圖片導出可以設置為遠程圖片地址,以及本地圖片地址,並且也可以設置為null(null將會被替代文本所代替)。效果如下圖:

3.使用Magicodes.IE.Excel導入圖片

Magicodes.IE.Excel支持從Excel導入圖片,僅需使用特性“ImportImageField”。其支持兩種導入方式:

  • 導入到臨時目錄
  • 導入為Base64

僅需設置ImportImageTo屬性。

ImportImageTo枚舉

  • Base64 導入為base64格式

  • TempFolder 導入到臨時目錄

值得註意的是,同上文一樣,圖片屬性欄位類型也僅支持string類型。

準備待導入的包含圖片的Excel

在開始之前,我們需準備好導入的Excel,本示例中的模板如下圖所示:

導入到臨時目錄

Dto模型如下所示:


    public class ImportPictureDto
    {
        [ImporterHeader(Name = "加粗文本")]
        public string Text { get; set; }
        [ImporterHeader(Name = "普通文本")]
        public string Text2 { get; set; }

        /// <summary>
        /// 將圖片寫入到臨時目錄
        /// </summary>
        [ImportImageField(ImportImageTo = ImportImageTo.TempFolder)]
        [ImporterHeader(Name = "圖1")]
        public string Img1 { get; set; }
        [ImporterHeader(Name = "數值")]
        public string Number { get; set; }
        [ImporterHeader(Name = "名稱")]
        public string Name { get; set; }
        [ImporterHeader(Name = "日期")]
        public DateTime Time { get; set; }

        /// <summary>
        /// 將圖片寫入到臨時目錄
        /// </summary>
        [ImportImageField(ImportImageTo = ImportImageTo.TempFolder)]
        [ImporterHeader(Name = "圖")]
        public string Img { get; set; }
    }

導入還是那個導入,只是Dto設置變了:

        public async Task ImportPicture_Test()
        {
            var filePath = Path.Combine(Directory.GetCurrentDirectory(), "TestFiles", "Import", "圖片導入模板.xlsx");
            var import = await Importer.Import<ImportPictureDto>(filePath);
            if (import.Exception != null) _testOutputHelper.WriteLine(import.Exception.ToString());

            if (import.RowErrors.Count > 0) _testOutputHelper.WriteLine(JsonConvert.SerializeObject(import.RowErrors));
        }

如下圖所示,Excel中的圖片就會導入到臨時目錄。值得註意的是:

  • 圖片導入到臨時目錄之後,如果導入結果符合業務需要,請立即將圖片移動到正式存儲位置,比如網站目錄、雲存儲等;
  • 圖片導入也支持指定位置,不過不推薦。

將圖片導入為base64

將圖片導入為base64僅需設置“ImportImageTo”屬性值為“ImportImageTo.Base64”即可:


    public class ImportPictureBase64Dto
    {
        [ImporterHeader(Name = "加粗文本")]
        public string Text { get; set; }
        [ImporterHeader(Name = "普通文本")]
        public string Text2 { get; set; }

        /// <summary>
        /// 將圖片導入為base64(預設為base64)
        /// </summary>
        [ImportImageField(ImportImageTo = ImportImageTo.Base64)]
        [ImporterHeader(Name = "圖1")]
        public string Img1 { get; set; }

        [ImporterHeader(Name = "數值")]
        public string Number { get; set; }
        [ImporterHeader(Name = "名稱")]
        public string Name { get; set; }
        [ImporterHeader(Name = "日期")]
        public DateTime Time { get; set; }

        /// <summary>
        /// 將圖片導入到臨時目錄
        /// </summary>
        [ImportImageField(ImportImageTo = ImportImageTo.TempFolder)]
        [ImporterHeader(Name = "圖")]
        public string Img { get; set; }
    }

導入代碼同上:


public async Task ImportPictureBase64_Test()
        {
            var filePath = Path.Combine(Directory.GetCurrentDirectory(), "TestFiles", "Import", "圖片導入模板.xlsx");
            var import = await Importer.Import<ImportPictureBase64Dto>(filePath);
        }

如下圖所示,我們就很方便的得到了圖片的base64編碼的結果:

Reference

https://github.com/dotnetcore/Magicodes.IE


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

-Advertisement-
Play Games
更多相關文章
  • 數組 聲明 類型[] 數組名//建議使用 類型 數組名[] 數組聲明後不會分配記憶體,必須new 數組名 = new 類型[大小] e.g. int [] arr = new int[8]; 使用 數組下標從0開始 賦值 數組名[下標]=數據 e.g. arr[5]=8; 訪問 數組名[下標] e.g ...
  • 前言 今天在測試環境發佈 服務,發現死活找不到錯誤的地方,錯誤日誌也生成,然後就一頓 ,一頓 ,發現日誌就截止到我發服務之前, 服務結束的地方,如圖所示。 WTF,why,我是丈二和尚摸不著頭腦,後來我發現他這個服務不是像我之前那種 啟動的,他這個是使用 啟動的。 正文 第六感告訴我,系統啟動日誌中 ...
  • 如果同一個IP短時間內多次訪問統一網頁,可能會被系統識別出是爬蟲,因此使用代理IP可以很大程度上解決這一問題 常用的代理有: 西刺免費代理:www.xicidaili.com 快代理:www.kuaidaili.com 代理雲:www.dailiyun.com 那麼我們如何知道自己的代理IP是否已經 ...
  • 作者:李小翀 鏈接:https://www.zhihu.com/question/22764869/answer/31277656 來源:知乎 1.初始 初始階段 的小型系統 應用程式、資料庫、文件等所有的資源都在一臺伺服器上通俗稱為LAMP特征:應用程式、資料庫、文件等所有的資源都在一臺伺服器上。 ...
  • ABP vNext(後文簡稱Abp)是 Volo 公司堪稱藝術品級的應用開發框架,它基於領域驅動設計(DDD)的思維,創新地採用了模塊化的設計。Abp 目前無疑是 ASP.NET Core 開發框架中最先進和最優雅的存在。筆者認為,憑藉絕妙的模塊化設計和絲滑的開發體驗,Abp 有望超越 Spring ...
  • 聚焦於 Xamarin 的 NET Conf 是一項免費的為期一天的直播活動,來自社區和.NET產品團隊的演講者正在使用Xamarin技術構建本機移動應用程式!Xamarin允許您使用C#(而不是Java和Swift)為Android和iOS構建本機移動應用程式。3月23日(星期一)下午8:00(太 ...
  • MurmurHash 是一種非加密型哈希演算法,適用於一般的哈希檢索操作,具有高性能、低碰撞率的特點。由 Google 的工程師 Austin Appleby 於2008年創建。MurmurHash 與其它流行的哈希函數相比,對於規律性較強的 Key,其隨機分佈特征表現的更好。非加密意味著著相對 MD ...
  • 問題:vm9里切換主機usb埠提示設備正在被使用,虛擬機里沒法使用主機usb設備,開始趟坑之旅。 1.說是vm里安裝usb3.0驅動。然而虛擬機幹啥啥不行,先win7更新sp1,再安裝KB2533623補丁,下載usb3.0驅動http://www.vmware.com/go/dl_intel_u ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...