4

我有 2 个对象列表。一个有价值观,另一个有名字和价值观。我想在另一个列表中查找值并将结果写入 pref.Name。我知道我可以用 foreach 做到这一点,但我认为在 LINQ 中有一个很好的方法。想法?

public class Preference
    {
        public string Category { get; set; }
        public string Name { get; set; }
        public string ItemValue { get; set; }
        public int SortOrder { get; set; }
    }

public class SAPReadOnlyItem
    {
        public string Category { get; set; }
        public string Name { get; set; }
        public string ItemValue { get; set; }
    }

    List<Preference> preferences = getExistingUserPreferences(UserID, ddlCategory.SelectedValue); //this list is just keys
    List<SAPReadOnlyItem> sapReadOnlyItems = getSAPReadOnlyItems(ddlCategory.SelectedValue); //this list is names and keys

    //i want to look up the name from sapReadOnly using the ID from preferences and write it into preferences[n].Name

    //this works, but I want to write it into preferences[n].Name
    var foobar = (from sap in sapReadOnlyItems
                  join pref in preferences 
                  on sap.ItemValue equals pref.ItemValue
                  select new { asdf = sap.Name }).FirstOrDefault(); //instead of "select new" I want to write it into preferences[n].Name
4

4 回答 4

6

我建议使用 Lambda foreach

preferences.ForEach(preference =>
                {
                    var sap = sapReadOnlyItems.FirstOrDefault(s => s.ItemValue = preference.ItemValue);
                    preference.Name = (sap != null) ? sap.Name : string.Empty;
                });
于 2013-03-05T11:44:42.747 回答
4

您可以使用标准 linq 运算符加入和分配名称:

var query = preferences.Join(sapReadOnlyItems, 
                             p => p.ItemValue, 
                             s => s.ItemValue, 
                             (p, s) => { p.Name = s.Name; return p; });
于 2012-10-16T20:57:02.400 回答
0

我想出了这个:

foreach (Preference pref in preferences)
{
    pref.Name = sapReadOnlyItems.Where(sapItem => sapItem.ItemValue == pref.ItemValue).FirstOrDefault().Name;
}
于 2012-10-16T19:02:39.470 回答
0

我不相信你想要的东西可以用特殊的 c# 语法来完成,而是你需要使用常规的方法链接语法。两种选择:

方法#1:

如果您想将它与 Linq 语法一起使用,这是一个 foreach 扩展方法:

sapReadOnlyItems.ForEach(s => preferences.Single(p => p.ItemValue == s.ItemValue).Name = s.Name);

与此一起使用:

public static void ForEach<T>(this IEnumerable<T> items, Action<T> action)
{
    foreach(T item in items)
    {
        action(item);
    }
}

方法#2:

如果您想要更新的首选项,您可以这样做:

var updatedPreferences = sapReadOnlyItems.Select(s => 
                         { 
                             var p = preferences.Single(p => p.ItemValue == s.ItemValue);
                             p.Name = s.Name;
                             return p;
                         });
于 2012-10-16T19:17:10.310 回答