日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

使用Magicodes.IE.Excel完成Excel图片的导入和导出

發布時間:2023/12/4 编程问答 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 使用Magicodes.IE.Excel完成Excel图片的导入和导出 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

說明

本章教程主要說明如何使用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;elseitem.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,本示例中的模板如下圖所示:

您可以在單元測試的“TestFiles”目錄中找到此文件。接下來我們就使用此文件來演示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編碼的結果:

轉載是一種動力 分享是一種美德

作者:hueifeng

如果喜歡作者的文章,請關注【麥扣聊技術】訂閱號以便第一時間獲得最新內容。本文版權歸作者和湖南心萊信息科技有限公司共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利。

文檔官網:docs.xin-lai.com

QQ群:

編程交流群<85318032>?

產品交流群<897857351>

總結

以上是生活随笔為你收集整理的使用Magicodes.IE.Excel完成Excel图片的导入和导出的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。