ASP.NET开源导入导出库Magicodes.IE完成Csv导入导出的方法

 更新时间:2020年06月04日 09:58:00   作者:HueiFeng  
这篇文章主要介绍了ASP.NET开源导入导出库Magicodes.IE完成Csv导入导出的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

说明

本章主要说明如何使用Magicodes.IE.Csv进行Csv导入导出.

关于Magicodes.IE

导入导出通用库,通过导入导出DTO模型来控制导入和导出,支持Excel、Word、Pdf和Html。

GitHub地址:https://github.com/xin-lai/Magicodes.IE

主要步骤

1.安装包Magicodes.IE.Csv

Install-Package Magicodes.IE.Csv

2.使用Magicodes.IE.Csv导出Csv

通过如下代码片段我们将导出的内容通过相应的特性做出相应的处理.

ExporterHeaderAttribute

  • DisplayName: 显示名称
  • Format: 格式化
  • IsIgnore: 是否忽略
  public class ExportTestDataWithAttrs
  {
    [ExporterHeader(DisplayName = "文本")]
    public string Text { get; set; }
    [ExporterHeader(DisplayName = "普通文本")] public string Text2 { get; set; }
    [ExporterHeader(DisplayName = "忽略", IsIgnore = true)]
    public string Text3 { 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; }

    /// <summary>
    /// 时间测试
    /// </summary>
    [ExporterHeader(DisplayName = "日期2", Format = "yyyy-MM-dd HH:mm:ss")]
    public DateTime? Time2 { get; set; }

    public DateTime Time3 { get; set; }

    public DateTime Time4 { get; set; }

    /// <summary>
    /// 长数值测试
    /// </summary>
    [ExporterHeader(DisplayName = "长数值", Format = "#,##0")]
    public long LongNo { get; set; }
  }

通过DTO导出

    public async Task ExportHeaderAsByteArray_Test()
    {
      IExporter exporter = new CsvExporter();

      var filePath = GetTestFilePath($"{nameof(ExportHeaderAsByteArray_Test)}.csv");

      DeleteFile(filePath);

      var result = await exporter.ExportHeaderAsByteArray(GenFu.GenFu.New<ExportTestDataWithAttrs>());
    }

3.使用Magicodes.IE.Csv导入Csv

对于csv导入我们可以通过,ImporterHeader Name属性去对应我们的Dto属性.并且可以通过ValueMapping对枚举类型进行相关的映射,并向我们返回相对应的值

    public async Task StudentInfoImporter_Test()
    {
      var filePath = Path.Combine(Directory.GetCurrentDirectory(), "TestFiles", "Import", "学生基础数据导入.csv");
      var import = await Importer.Import<ImportStudentDto>(filePath);
    }
 /// <summary>
  /// 导入学生数据Dto
  /// </summary>
  public class ImportStudentDto
  {
    /// <summary>
    ///   序号
    /// </summary>
    [ImporterHeader(Name = "序号")]
    public long SerialNumber { get; set; }

    /// <summary>
    ///   学籍号
    /// </summary>
    [ImporterHeader(Name = "学籍号")]
    public string StudentCode { get; set; }
    /// <summary>
    ///   姓名
    /// </summary>
    [ImporterHeader(Name = "姓名")]
    public string Name { get; set; }

    /// <summary>
    ///   身份证号码
    /// </summary>
    [ImporterHeader(Name = "身份证号")]
    public string IdCard { get; set; }

    /// <summary>
    ///   性别
    /// </summary>
    [ImporterHeader(Name = "性别")]
    [ValueMapping("男", 0)]
    [ValueMapping("女", 1)]
    public Genders Gender { get; set; }

    /// <summary>
    ///   家庭地址
    /// </summary>
    [ImporterHeader(Name = "家庭住址")]
    public string Address { get; set; }

    /// <summary>
    ///   家长姓名
    /// </summary>
    [ImporterHeader(Name = "家长姓名")]
    public string Guardian { get; set; }

    /// <summary>
    ///   家长联系电话
    /// </summary>
    [ImporterHeader(Name = "家长联系电话")]
    public string GuardianPhone { get; set; }

    /// <summary>
    ///   学号
    /// </summary>
    [ImporterHeader(Name = "学号")]
    public string StudentNub { get; set; }

    /// <summary>
    ///   宿舍号
    /// </summary>
    [ImporterHeader(Name = "宿舍号")]
    public string DormitoryNo { get; set; }

    /// <summary>
    ///   QQ
    /// </summary>
    [ImporterHeader(Name = "QQ号")]
    public string QQ { get; set; }

    /// <summary>
    ///   民族
    /// </summary>
    [ImporterHeader(Name = "民族")]
    public string Nation { get; set; }

    /// <summary>
    ///   户口性质
    /// </summary>
    [ImporterHeader(Name = "户口性质")]
    public string HouseholdType { get; set; }

    /// <summary>
    ///   联系电话
    /// </summary>
    [ImporterHeader(Name = "学生联系电话")]
    public string Phone { get; set; }

    /// <summary>
    ///   状态
    ///   测试可为空的枚举类型
    /// </summary>
    [ImporterHeader(Name = "状态")] 
    public StudentStatus? Status { get; set; }

    /// <summary>
    ///   备注
    /// </summary>
    [ImporterHeader(Name = "备注")]
    public string Remark { get; set; }

    /// <summary>
    ///   是否住校(宿舍)
    /// </summary>
    [ImporterHeader(IsIgnore = true)]
    public bool? IsBoarding { get; set; }

    /// <summary>
    ///   所属班级id
    /// </summary>
    [ImporterHeader(IsIgnore = true)]
    public Guid ClassId { get; set; }

    /// <summary>
    ///   学校Id
    /// </summary>
    [ImporterHeader(IsIgnore = true)]
    public Guid? SchoolId { get; set; }

    /// <summary>
    ///   校区Id
    /// </summary>
    [ImporterHeader(IsIgnore = true)]
    public Guid? CampusId { get; set; }

    /// <summary>
    ///   专业Id
    /// </summary>
    [ImporterHeader(IsIgnore = true)]
    public Guid? MajorsId { get; set; }

    /// <summary>
    ///   年级Id
    /// </summary>
    [ImporterHeader(IsIgnore = true)]
    public Guid? GradeId { get; set; }
  }

Reference

https://github.com/dotnetcore/Magicodes.IE

到此这篇关于ASP.NET开源导入导出库Magicodes.IE完成Csv导入导出的方法的文章就介绍到这了,更多相关ASP.NET Csv导入导出内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • ASP.NET防止页面刷新的两种解决方法小结

    ASP.NET防止页面刷新的两种解决方法小结

    本篇文章主要是对ASP.NET防止页面刷新的两种解决方法进行了详细的分析介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2014-01-01
  • 有关.NET参数传递的方式引发的思考

    有关.NET参数传递的方式引发的思考

    在.NET中参数的使用方法主要为可选参数、命名参数、可变数量参数等等。本文也是主要介绍这三种参数的使用方法
    2016-12-12
  • html+ashx 表单提交示例

    html+ashx 表单提交示例

    这篇文章主要介绍了html+ashx 表单提交的具体实现,需要的朋友可以参考下
    2014-03-03
  • ASP.NET中保护自定义的服务器控件

    ASP.NET中保护自定义的服务器控件

    本文提供了针对自定义服务器控件的用户和开发人员的基本安全准则。适合初学者,希望对你有帮助,一起来看。
    2015-10-10
  • 页面间隔半秒钟更新时间 Asp.net使用Comet开发http长连接示例分享

    页面间隔半秒钟更新时间 Asp.net使用Comet开发http长连接示例分享

    Comet(Reverse AJAX)主要是通过HTTP长连接, 保持和服务器的连接,实现Server PUSH 和双向通信,下面通过示例学习他的使用方法
    2014-01-01
  • asp.net删除文件session丢失

    asp.net删除文件session丢失

    如果你曾经修改了ASP.NET应用程序(dll文件),与修改了bin文件夹或Web.config文件(添加/删除/重命名的文件等),而该网站在运行,你可能已经注意到,这将导致在AppDomain的重新启动
    2010-09-09
  • MVC网站开发之权限管理篇

    MVC网站开发之权限管理篇

    这篇文章主要为大家详细介绍了MVC网站开发之权限管理的相关资料,感兴趣的小伙伴们可以参考一下
    2016-08-08
  • asp.net(c#) ubb处理类

    asp.net(c#) ubb处理类

    asp.net下对于编辑器中的ubb进行替换处理的实现代码
    2008-08-08
  • asp.net 程序优化精选

    asp.net 程序优化精选

    对于asp.net需要注意的一些事项,可以提高你的程序运行效率。
    2009-04-04
  • ASP.NET MVC5网站开发文章管理架构(七)

    ASP.NET MVC5网站开发文章管理架构(七)

    继上一篇把member的用户部分完成,现在开始做文章管理部分。文章部分根据涉及显示现实文章列表,发布文章,修改和删除文章等功能。最终的实现目标是使用权限来控制用户是否能进行相应操作,管理员权限的会显示全部文章列表和我的文章列表,普通用户只显示我的文章列表
    2015-09-09

最新评论