的Where
方法僅返回該項目是否應該被包括在結果還是不行。該功能無法以合理的方式提供更多信息(它可以捕獲局部變量並對其進行處理,但這太可怕了)。
如果您想要最終結果中的索引,您需要創建一個包含該索引的投影。如果您想在最終結果中使用原始索引,則需要將該投影放在任何Where
子句之前。
這裏有一個例子:
using System;
using System.Collections.Generic;
using System.Linq;
public class Test
{
static void Main()
{
IEnumerable<char> letters = "aBCdEFghIJklMNopQRsTUvWyXZ";
var query = letters.Select((c, i) =>
new { Char=c, OriginalIndex=i })
.Where(x => char.IsLower(x.Char))
.Select((x, i) =>
new { x.Char,
x.OriginalIndex,
FinalIndex=i});
foreach (var result in query)
{
Console.WriteLine(result);
}
}
}
結果:
{ Char = a, OriginalIndex = 0, FinalIndex = 0 }
{ Char = d, OriginalIndex = 3, FinalIndex = 1 }
{ Char = g, OriginalIndex = 6, FinalIndex = 2 }
{ Char = h, OriginalIndex = 7, FinalIndex = 3 }
{ Char = k, OriginalIndex = 10, FinalIndex = 4 }
{ Char = l, OriginalIndex = 11, FinalIndex = 5 }
{ Char = o, OriginalIndex = 14, FinalIndex = 6 }
{ Char = p, OriginalIndex = 15, FinalIndex = 7 }
{ Char = s, OriginalIndex = 18, FinalIndex = 8 }
{ Char = v, OriginalIndex = 21, FinalIndex = 9 }
{ Char = y, OriginalIndex = 23, FinalIndex = 10 }
感謝喬恩,這清除了事情。我只是確保我沒有錯過Where方法的某些東西,或者可能還有其他的東西需要放入或放入。我需要閱讀更多。 – 2009-04-29 20:46:04