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

简介:

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

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

主要步骤
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);
    }

///

/// 导入学生数据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

原文地址https://www.cnblogs.com/yyfh/p/12886258.html

相关文章
|
6天前
|
C# Windows
.NET开源免费的Windows快速文件搜索和应用程序启动器
今天大姚给大家分享一款.NET开源(MIT License)、免费、功能强大的Windows快速文件搜索和应用程序启动器:Flow Launcher。
|
6天前
|
C#
.NET开源、免费、强大的交互式绘图库
.NET开源、免费、强大的交互式绘图库
|
6天前
|
存储 文字识别 C#
.NET开源免费、功能强大的 Windows 截图录屏神器
今天大姚给大家分享一款.NET开源免费(基于GPL3.0开源协议)、功能强大、简洁灵活的 Windows 截图、录屏、Gif动图制作神器:ShareX。
|
6天前
|
数据可视化 开发工具 C#
.NET开源、免费、跨平台的Git可视化管理工具
俗话说得好“工欲善其事,必先利其器”,合理的选择和使用可视化的管理工具可以降低技术入门和使用的门槛。今天大姚给大家分享一款.NET Avalonia开源、免费、跨平台、快速的Git可视化管理工具:SourceGit。
|
6天前
|
小程序 C# 数据库
3个.NET开源、免费、强大的商城系统
今天大姚给大家分享3个.NET开源、免费、强大的商城系统,希望可以帮助到有商城系统开发需求的同学。
|
6天前
|
开发框架 JavaScript 前端开发
5个.NET开源且强大的快速开发框架(帮助你提高生产效率)
5个.NET开源且强大的快速开发框架(帮助你提高生产效率)
114 4
|
6天前
|
前端开发 C# 数据库
.NET中使用BootstrapBlazor组件库Table实操篇
.NET中使用BootstrapBlazor组件库Table实操篇
|
6天前
|
定位技术 API C#
.NET开源、功能强大、跨平台的图表库
.NET开源、功能强大、跨平台的图表库
|
6天前
|
C#
一个库帮你轻松的创建漂亮的.NET控制台应用程序
一个库帮你轻松的创建漂亮的.NET控制台应用程序
|
6天前
|
搜索推荐 API C#
.NET开源快速、强大、免费的电子表格组件
.NET开源快速、强大、免费的电子表格组件

热门文章

最新文章