美文网首页dotNET程序员
对LinqtoExcel的扩展 【数据有限性,逻辑有效性】

对LinqtoExcel的扩展 【数据有限性,逻辑有效性】

作者: HapplyFox | 来源:发表于2018-07-11 15:58 被阅读2次

接着上文的内容继续讲,上文中我提到了对Excel操作帮助类库LinqToExcel类库的优缺点和使用方法。我也讲到了自己在使用中碰到的问题,我也开发了一个简单的类库解决,下面就讲解一下这个帮助类。


Github链接 LinqToExcel.Extend
LinqToExcel没有包含验证,在无法保证客户提供的Excel数据规范的前提下容易发生错误。所以对其进行扩展,扩展的内容主要就是在实体转换前对数据进行验证。
经过网络的简单学习,我总结验证包含俩点
1.默认验证参数有效性
2.自定是逻辑有效性

数据有效性

数据有效性主要指的是Excel单元格字段类型是否和定义的实体类属性字段一致,如果不一致需要提示。例如定义了一个字段Datetime,但是传进来的内容是2018年9月33日。这种不符合要求的数据就是有问题的值。

逻辑有效性

逻辑有效性这个就更加好理解了,Excel的单元格只允许出现 这俩值,可是用户却填写了不是这样的值,后来在验证的时候就要过滤并给出错误提示

我的扩展主要就是基于这俩个内容,大概的代码贴图如下。
如果要验证Excel的数据是否满足条件我们New一个WorkBookValidate对象,参数是Excel路径。
然后我们执行方法,如果我们想要验证第一个工作表是否符合User实体类的要求,代码就是这样workbook[0].StartValidate<User>();

//自定义工作簿验证
WorkBookValidate workbook = new WorkBookValidate("Default.xlsx");
//验证结束返回Verification对象,对象包含 俩个属性,一个为是否验证成功,一个为验证出错的集合信息
workbook[0].StartValidate<User>();

需要验证的实体,这里的内容和LinqToExcel定义不变,还是使用相同的特性标签。

public class User {

[ExcelColumn("Id")]
public string ID { get; set; }

[ExcelColumn("名称")]
public string Name { get; set; }

[ExcelColumn("年龄")]
public int Age { get; set; }

[ExcelColumn("出生日期")]
public DateTime BirthDay { get; set; }

public override string ToString()
{
    return string.Format("{0}\t{1}\t{2}", ID, Name, Age);
}
}

这里主要是对各种事例的说明,主要分三个方法讲解

对出错对象的输出,是下面例子的通用方法

    private static void Validate(Verification verifity)
    {
        Console.WriteLine(string.Format("是否通过{0}", verifity.IfPass));
        //出错列
        foreach (var item in verifity.ErrCells)
        {
            Console.WriteLine(item);
        }
    }

BasicValidate

首先第一个方法BasicValidate,很标准的一个Action,相信大家能够看懂,实例化对象,执行方法,打印错误字段

 /// <summary>
    /// 基础验证 通过实体特性
    /// </summary>
    public static void BasicValidate()
    {
        WorkBookValidate workbook = new WorkBookValidate("Default.xlsx");
        var errlist = workbook[0].StartValidate<User>();
        Validate(errlist);
    }

BasicValidate2

第二个方法BasicValidate2,和第一个方法类似,只是多了一个实体映射的方法,这个方法和LinqToExcel的方法使用类似,如果实体类未定义映射的特性标签,那么就通过如下方式自定义设置

    /// <summary>
    /// 基础验证 自定义对应关系
    /// </summary>
    public static void BasicValidate2()
    {
        WorkBookValidate workbook = new WorkBookValidate("Other.xlsx");

        workbook[0].AddMapping("ID", "主键");
        var errlist = workbook[0].StartValidate<User>();
        Validate(errlist);
    }

ValidateWithCondition

第三个方法ValidateWithCondition主要是增加了逻辑有效性验证,调用上述俩个方法,就相当于执行的是数据有效性验证,如果要增加逻辑有效性验证,只需要多添加一个参数就可以,参数如下所示
首先是验证的字段
然后是验证条件
最后是出错的提示信息

    /// <summary>
    /// 带条件验证
    /// </summary>
    public static void ValidateWithCondition()
    {
        WorkBookValidate workbook = new WorkBookValidate("Default.xlsx");

        List<CellMatching<User>> rowValidate = new List<CellMatching<User>>();
        rowValidate.Add(new CellMatching<User>()
        {
            paramater = u => u.Age,
            matchCondition = u => u.Age > 10,
            errMsg = "请选择年龄大于10的人员"
        });

        var errlist = workbook[0].StartValidate<User>(rowValidate);
        Validate(errlist);
    }
    

总结

以上主要是对API使用的一些说明,大家可以自行下载代码。希望大家一起提出好的意见,一起优化,一起进步,一起学习。

相关文章

  • 对LinqtoExcel的扩展 【数据有限性,逻辑有效性】

    接着上文的内容继续讲,上文中我提到了对Excel操作帮助类库LinqToExcel类库的优缺点和使用方法。我也讲到...

  • 运营新人应该看哪些培养数据思维的书籍?

    数据思维对从事运营同学而言是一项非常重要的基础能力,基于数据与逻辑做出的决策判断,在效率、有效性上显著优于基于感性...

  • 算法的含义和数据的结构

    算法的含义 算法包含:输入输出明确性有限性有效性 数据结构 我们要解决一个跟数据相关的问题 分析这个问题,想出对应...

  • 共学《投资最重要的事》 Day02

    第2章 理解市场有效性及局限性思考: 什么是市场有效性假说? 市场价格代表了对资产内在价值的准确估计,任何参与者都...

  • 基础篇

    Linux学习 一、LVM讲解 LVM有一定的局限性;数据恢复困难 物理分区==>物理卷==>卷组==>逻辑卷 准...

  • EXCEL中如何控制每列数据的长度并避免重复录入

    1、用数据有效性定义数据长度。 用鼠标选定你要输入的数据范围,点"数据 "-"有效性"-"设置", "有效性条件"...

  • PL/SQL入门使用详解

    前言 PL/SQL是Oracle数据库对SQL语句的扩展,可以让我们实现if、else等逻辑判断、for循环执行等...

  • 【Excel成长记】数据有效性

    数据有效性 数据有效性是在尚未输入数据时,预先设置,对单元或单元格区域输入的数据从内容到数量上进行限制,对于符合条...

  • NoSql相关

    什么是Nosql 指非关系型数据库(Nosql),为了解决关系型数据库,数据表示的局限性应用于高性能、高扩展、高并...

  • cookie的优缺点?

    cookie虽然在持久保存客户端数据提供了方便,分担了服务器存储的负担,但还是有很多局限性的。 优点:极高的扩展性...

网友评论

    本文标题:对LinqtoExcel的扩展 【数据有限性,逻辑有效性】

    本文链接:https://www.haomeiwen.com/subject/mhhxpftx.html