.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;
 }

导出文件效果

相关推荐
嵌入式小能手8 小时前
飞凌嵌入式ElfBoard-进程间的通信之信号处理sigaction
linux·算法·信号处理
剑神一笑8 小时前
Linux top 命令深度解析:进程监控的性能优化实战
linux·运维·正则表达式
jimy18 小时前
Oracle云e2.1.micro优化tailscale的exit模式网速
linux·服务器·oracle
楼田莉子8 小时前
Linux网络:网络多路IO模型详解
linux·网络·数据库
嵌入式小能手8 小时前
飞凌嵌入式ElfBoard-进程间的通信之信号处理signal
linux·服务器·信号处理
Irene19919 小时前
Linux 中换行符 = 命令结束,xargs 防止意外执行的机制,不支持标准输入的命令,-i 在各个命令中的真实含义
linux
Edward111111119 小时前
SSL/TSL配置 集群节点间通信加密还有客户端
linux·服务器·ssl
Codigger官方9 小时前
Ubuntu 与 Fedora:两大 Linux 发行版怎么选?
linux·运维·ubuntu
程序员老舅9 小时前
Linux:谁把根目录卸载了?
linux·c++·容器·linux内核·文件系统·根目录
东北甜妹9 小时前
K8s pod优先级 和 HPA水平扩缩容
linux·运维·服务器