爲了更好的根據實際功能來迭代,從2.2的里程碑規劃開始,咱們將結合社區的建議和意見來進行迭代,您能夠點此連接來提交您的意見和建議:
https://github.com/dotnetcore/Magicodes.IE/issues/46git
本章教程主要說明如何使用Magicodes.IE.Excel進行圖片的導入導出。github
/// <summary> /// 圖片導入類型 /// </summary> public enum ImportImageTo { /// <summary> /// 導入到臨時目錄 /// </summary> TempFolder, /// <summary> /// 導入爲base64格式 /// </summary> Base64 }
Install-Package Magicodes.IE.Excel
以下述示例代碼所示,咱們須要在圖片屬性上添加ExportImageFieldAttribute特性,使用特性的「Width」屬性指定圖片寬度,「Height」屬性指定圖片高度,「Alt」屬性指定替換文本,也就是當圖片不存在時則會顯示此文本:shell
[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; } }
值得注意的是:async
接下來,咱們就能夠使用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將會被替代文本所代替)。效果以下圖:網站
Magicodes.IE.Excel支持從Excel導入圖片,僅需使用特性「ImportImageField」。其支持兩種導入方式:編碼
僅需設置ImportImageTo屬性。url
ImportImageTo枚舉excel
Base64 導入爲base64格式code
TempFolder 導入到臨時目錄
值得注意的是,同上文同樣,圖片屬性字段類型也僅支持string類型。
在開始以前,咱們需準備好導入的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僅需設置「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編碼的結果: