首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >匹配单个值的DataTable AsEnumerable

匹配单个值的DataTable AsEnumerable
EN

Stack Overflow用户
提问于 2018-01-10 20:08:42
回答 2查看 2.6K关注 0票数 1

假设我的查询返回一个DataTable,它是一个电子邮件地址列表,一个名为“email”的varchar列;这些电子邮件被授权做一些事情。

代码语言:javascript
复制
jane@doe.com
mike@foo.com
donald@duck.com

当前登录的用户是harry@houdini.com。他没有被授权。他不在名单上

是否可以使用Linq迭代DataRows并返回布尔false

还是返回一个对象,即nullNothing或空?

本质上,我想知道

代码语言:javascript
复制
 Authorized = List.Contains( "harry@houdini.com")

我真的很想知道如何在C#和VB中做到这一点。

谢谢

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-01-10 20:28:02

下面是使用DataTable的示例,如下所示

C#

代码语言:javascript
复制
        DataTable dt = new DataTable();
        dt.Columns.Add("emails");
        dt.Rows.Add("jane@doe.com");
        dt.Rows.Add("mike@foo.com");
        dt.Rows.Add("donald@duck.com");

        var authorized = dt.AsEnumerable().Any(s => s[0].Equals("mike@foo.com")); //returns True
        var notAuthorized = dt.AsEnumerable().Any(s => s[0].Equals("harry@houdini.com"));  //returns False

VB中(在线转换)

代码语言:javascript
复制
        Dim dt As DataTable = New DataTable
        dt.Columns.Add("emails")
        dt.Rows.Add("jane@doe.com")
        dt.Rows.Add("mike@foo.com")
        dt.Rows.Add("donald@duck.com")
        Dim authorized As var = dt.AsEnumerable.Any(() => {  }, 
           s(0).Equals("mike@foo.com"))
        Dim notAuthorized As var = dt.AsEnumerable.Any(() => {  }, 
           s(0).Equals("harry@houdini.com"))
票数 2
EN

Stack Overflow用户

发布于 2018-01-10 20:11:08

Any在这里可能更干净:

代码语言:javascript
复制
bool exists = dataTable.AsEnumerable()
                       .Any(r => "harry@houdini.com".Equals(r[0]));

您可以将列投影到字符串集合中,并使用Contains,但这里似乎有些过分。

或定义主键并在DataRowCollection上使用本机Contains方法。

代码语言:javascript
复制
dataTable.PrimaryKey = dataTable.Columns[0];
bool exists = dataTable.Rows.Contains("harry@houdini.com");
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/48195290

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档