.net core在linux导出excel,System.Drawing.Common is not supported on this platform

使用框架 .NET7

导出组件 Aspose.Cells for .NET 5.3.1

asp.net core mvc 如果使用Aspose.Cells导出excel时,报错

System.Drawing.Common is not supported on this platform

平台特定实现:

对于Windows平台,System.Drawing.Common 通常是可以正常工作的。

对于非Windows平台,你可能需要寻找替代方案,如使用 SkiaSharp、ImageSharp 或其他跨平台的图形库。

System.Drawing.Common 是一个提供基本图形功能的库,但它并不是在所有平台上都可用。特别是在非Windows平台上(如Linux和macOS),由于底层图形系统的差异,直接使用 System.Drawing.Common 可能会遇到问题

推荐使用不依赖操作系统底层环境的组件来导出excel,这样linux中就不用安装图像组件依赖了,比如libSkiaSharp,这里推荐用 MiniExcel 来导出excel,支持Linux,直接在nuget搜索安装MiniExcel

MiniExcel 组件介绍

MiniExcel 简单高效,避免了 OOM 的 .NET 处理 Excel 工具。

目前大多数流行的框架都需要将所有数据加载到内存中以方便操作,但这会引起内存消耗问题。MiniExcel 尝试使用流中的算法将原来的 1000 MB 占用减少到几 MB,以避免 OOM(内存不足)。

特征

  • 低内存消耗,避免 OOM(内存不足)和全量 GC
  • 支持每行数据的实时操作
  • 支持 LINQ 延迟执行,可以做低消耗、快速分页等复杂查询
  • 轻量级,未安装 Microsoft Office,无 COM+,DLL 大小小于 150KB
  • 简单的 API 样式来读/写/填充 excel

MiniExcel 导出excel参考代码:

csharp 复制代码
 public static string ExportExcelFile(Object list, string fileName)
 {
     //检查导出目录是否在 
     string dir = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "export");
     if (!System.IO.Directory.Exists(dir))
     {
         System.IO.Directory.CreateDirectory(dir);
     }

     string filePath = Path.Combine(dir, fileName);
 
     string url = Path.Combine("export", fileName);

//测试数据
     var value = new[] {
         new { id="12",name="武松",createTime="2024-12-17 16:35:41",point=284.7},
         new { id="23",name="李斯",createTime="2024-12-11 16:35:41",point=184.5},
         new { id="31",name="欧阳楠",createTime="2024-10-14 16:35:41",point=384.1},
         new { id="14",name="范仲淹",createTime="2024-05-24 16:35:41",point=291.2}
     };

     var config = new OpenXmlConfiguration
     {
            /*
      * new DynamicExcelColumn("id"){Name="主键" } , Name设置列中文名称;
       new DynamicExcelColumn("id"){Name="主键" ,Ignore=true} , Ignore表示此列不导出;
       Index设置所在列下标(数字),也可以控制显示顺序; 
      */
         //配置列名
         DynamicColumns = new DynamicExcelColumn[] {
             new DynamicExcelColumn("id"){Name="主键" },
             new DynamicExcelColumn("name"){ Name="姓名",Width=20},
             new DynamicExcelColumn("createTime"){Name="创建时间", Format="yyyy-MM-dd",Width=55},
             new DynamicExcelColumn("point"){ Name="得分"},
         }
     };

     MiniExcel.SaveAs(filePath, value, configuration: config);



     //删除已经过期的文件
     Action<string> delFileAc = (fileDir) =>
     {
         try
         {
             var files = System.IO.Directory.GetFiles(fileDir);
             if (files == null || files.Length == 0) return;
             foreach (var filePath in files)
             {
                 if (File.Exists(filePath))
                 {
                     var fileInfo = new FileInfo(filePath);
                     if ((DateTime.Now - fileInfo.LastWriteTime).TotalHours > 48)
                     {
                         File.Delete(filePath);
                         Console.WriteLine("成功删除导出文件=" + filePath);
                     }
                 }
             }
         }
         catch (Exception)
         {
         }
     };
     delFileAc(dir);

     return url;
 }

导出文件效果

相关推荐
小糖学代码15 小时前
Linux:11.线程概念与控制
linux·服务器·c语言·开发语言·c++
YouEmbedded18 小时前
解码Linux文件IO目录检索与文件属性
linux·文件属性·文件io·目录检索
大聪明-PLUS21 小时前
关于新的 Linux 内核接口 gpio uapi 的说明
linux·嵌入式·arm·smarc
玉树临风江流儿21 小时前
Linux驱动开发总结速记
linux·运维·驱动开发
cccyi721 小时前
Linux 进程信号机制详解
linux·signal·volatile
技术钱21 小时前
vue3 封装图片上传预览组件支持docx、excel、pdf、图片、txt格式
vue.js·pdf·excel
gd63213741 天前
银河麒麟 aarch64 linux 里面的 qt 怎么安装kit
linux·服务器·qt
A-花开堪折1 天前
Qemu 嵌入式Linux驱动开发
linux·运维·驱动开发
磊灬泽1 天前
【Linux驱动开发】PWM子系统-servo
linux·运维·算法
r i c k1 天前
Excel表----VLOOKUP函数实现两表的姓名、身份证号码、银行卡号核对
excel