繁体   English   中英

Func返回任何类型

[英]Func Return Any Type

我有以下属性类:

class tbl_tax_type
{
    public int TAXT_ID { get; set; }
    public string BFNS_CODE { get; set; }
    public string TAXT_CODE { get; set; }
    public string TAXT_DESC { get; set; }
    public string ACCT_CODE { get; set; }
    public DateTime CREATED_DATE { get; set; }
    public string CREATED_BY { get; set; }
    public Nullable<DateTime> LAST_MODIFIED_DATE { get; set; }
    public string LAST_MODIFIED_BY { get; set; }
    public string TAXT_STATUS { get; set; }
}

我使用下面的方法从中检索数据:

private static List<T> SelectData<T>(Expression<Func<T, bool>> PredicateExp) where T : new()
{ 
    return FireCon().Table<T>().Where(PredicateExp).ToList();
}

按用法(下面的代码从tbl_tax_type中选择行,其中BFNS_CODE等于0605)

List<tbl_tax_type> TempList = SelectData<Tbl.tbl_tax_type>(taxtype => taxtype.BFNS_CODE == "0605")

现在我想对所选数据进行区分,所以我想到了这个方法。

public static List<T> DistinctBy<T>(List<T> MyList, Func<T, __> SelectorExpr)
{
    return GenericList.Select(SelectorExpr).Distinct().ToList();
}

按用法(下面的代码选择不同的TAXT_CODE)

DistinctBy(TempList, v => v.TAXT_CODE);

缺少一些东西,选择表达式的TResult。 我希望它返回任何类型的数据,因为tbl_tax_type的属性具有不同的数据类型。 这可能吗?

你的意思是......

public static List<S> DistinctBy<T, S>(List<T> myList, Func<T, S> selectorExpr)
{
    return myList.Select(selectorExpr).Distinct().ToList();
}

尝试这个:

public static List<T> DistinctBy<T, S>(List<T> myList, Func<T, S> selectorExpr)
{
    return myList.ToLookup(selectorExpr).SelectMany(t => t.Take(1)).ToList();
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM