Воссоздание словаря из IEnumerable>


у меня есть метод, который возвращает IEnumerable<KeyValuePair<string, ArrayList>>, но некоторые из вызывающих объектов требуют, чтобы результатом метода был словарь. Как я могу преобразовать IEnumerable<KeyValuePair<string, ArrayList>> на Dictionary<string, ArrayList> так что я могу использовать TryGetValue?

способ:

public IEnumerable<KeyValuePair<string, ArrayList>> GetComponents()
{
  // ...
  yield return new KeyValuePair<string, ArrayList>(t.Name, controlInformation);
}

звонящий:

Dictionary<string, ArrayList> actual = target.GetComponents();
actual.ContainsKey("something");
2 146

2 ответа:

Если вы используете .NET 3.5 или .NET 4, легко создать словарь с помощью LINQ:

Dictionary<string, ArrayList> result = target.GetComponents()
                                      .ToDictionary(x => x.Key, x => x.Value);

нет такой вещи, как IEnumerable<T1, T2> но a KeyValuePair<TKey, TValue> - это хорошо.

создание объекта словаря из Datable с помощью IEnumerable

using System.Data;
using ..


public class SomeClass {
    //define other properties
    // ...  

    public Dictionary<string, User> ConvertToDictionaryFromDataTable(DataTable myTable, string keyColumnName)
        {
            // define IEnumerable having one argument of KeyValuePair
            IEnumerable<KeyValuePair<string,User>> tableEnumerator = myTable.AsEnumerable().Select(row => 
                {
                    // return key value pair
                    return new KeyValuePair<string,User>(row[keyColumnName].ToString(),                        
                        new User 
                        {
                            UserID=row["userId"].ToString(),
                            Username=row["userName"].ToString(),
                            Email=row["email"].ToString(),
                            RoleName=row["roleName"].ToString(),
                            LastActivityDate=Convert.ToDateTime(row["lastActivityDate"]),
                            CreateDate=Convert.ToDateTime(row["createDate"]),
                            LastLoginDate=Convert.ToDateTime(row["lastLoginDate"]),
                            IsActive=Convert.ToBoolean(row["isActive"]),
                            IsLockedOut=Convert.ToBoolean(row["isLockedOut"]),
                            IsApproved=Convert.ToBoolean(row["isApproved"])
                        });
                });
            return tableEnumerator.ToDictionary(x => x.Key, x => x.Value);
        }

}


public class User
{

    public string UserID { get; set; }       
    public string Username { get; set; }
    public string Email { get; set; }
    public string RoleName { get; set; }       
    public DateTime LastActivityDate { get; set; }
    public DateTime CreateDate { get; set; }
    public DateTime LastLoginDate { get; set; }
    public bool IsActive { get; set; }
    public bool IsLockedOut { get; set; }
    public bool IsApproved { get; set; }                

// Other methods to follow..
}



        IEnumerable<KeyValuePair<string,User>> ieUsers = membershipUsers.AsEnumerable().Select(row =>
            {
                return new KeyValuePair<string,User>(row.UserName.ToString(),
                    new User
                    {
                        Username = row.UserName.ToString(),
                        Email = row.Email.ToString()
                    });
            });
        allMembershipUsers = ieUsers.ToDictionary(x => x.Key, x => x.Value);
        return allMembershipUsers;
    }
}