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

导出文件效果

相关推荐
菜菜笔记35 分钟前
Ubuntu 挂载新盘
linux·运维·ubuntu
慌糖1 小时前
Ubuntu安装Docker命令清单(以20.04为例)
linux·ubuntu·docker
zhangzhiwei-zzw1 小时前
Linux下使用nmcli连接网络
linux·网络·chrome
ZZH1120KQ2 小时前
Linux账号和权限管理
linux·运维
XMAIPC_Robot2 小时前
基于 ZYNQ UltraScale+ OV5640的高速图像传输系统设计,支持国产替代
linux·数码相机·fpga开发·架构·边缘计算
水水沝淼㵘2 小时前
嵌入式开发学习日志(linux系统编程--系统编程之 进程间通信IPC)Day32
linux·运维·学习
IT小饕餮2 小时前
linux登陆硬件检测脚本
linux·运维·服务器
在成都搬砖的鸭鸭3 小时前
【Golang】使用gin框架导出excel和csv文件
golang·excel·gin
碎梦归途4 小时前
Linux 软件安装方式全解(适用于 CentOS/RHEL 系统)
linux·运维·centos
啃火龙果的兔子4 小时前
CentOS 7.9 安装 宝塔面板
linux·运维·centos