是否有适用于Where 和Select 的(T, int) 重载的LINQ 语法?

发布于 2024-09-20 00:22:12 字数 350 浏览 3 评论 0原文

该查询

var q = from elem in collection
        where someCondition(elem)
        select elem;

将转换为

var q = collection.Where(elem => someCondition(elem));

是否有可转换为以下内容的 LINQ 语法?

var q = collection.Where((elem, index) => someCondition(elem, index));

The query

var q = from elem in collection
        where someCondition(elem)
        select elem;

translates to

var q = collection.Where(elem => someCondition(elem));

Is there a LINQ syntax that would translate to the following?

var q = collection.Where((elem, index) => someCondition(elem, index));

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

睫毛上残留的泪 2024-09-27 00:22:13

不,没有 LINQ 语法。

一个简单的解决方法可能是:

var q = from elem in collection.Select((x,i) => new {x,i})
        where someCondition(elem.x,elem.i)
        select elem.x;

No there's no LINQ syntax for that.

A simple work-around could be:

var q = from elem in collection.Select((x,i) => new {x,i})
        where someCondition(elem.x,elem.i)
        select elem.x;
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文