我有一个对象列表,其中包含销售人员的团队详细信息。 该列表有几个具有相同名称但销售人员不同的团队。
teamDetails类具有以下属性:
string teamName;
string region;
int teamSales;
string salesmanFullName;
string salesmanAddress;
用户可以选择查找销售额超过特定值的所有团队。然后将这些团队添加到复选框列表中。
这就是我填写复选框列表的方式:
var viewList = from toSearch in GlobalVariables.allSalesmenList
where toSearch.teamSales > Convert.ToInt32(txtSalesSearch.Text)
select toSearch;
SearchCheckedListBox.DataSource = viewList.ToList();
SearchCheckedListBox.DisplayMember = "teamName";
我遇到的问题是,如果团队中有多个推销员,团队名称会不止一次显示。
如何阻止复选框重复出现值?
答案 0 :(得分:1)
尝试使用distinct与comparer:
var viewList = from toSearch in GlobalVariables.allSalesmenList
where toSearch.teamSales > Convert.ToInt32(txtSalesSearch.Text)
select toSearch;
SearchCheckedListBox.DataSource = viewList.Distinct(new TeamComparer()).ToList();
SearchCheckedListBox.DisplayMember = "teamName";
比较代码:
public class TeamComparer : IEqualityComparer<teamDetails>
{
public bool Equals(teamDetails x, teamDetails y)
{
if (x.teamName == y.teamName) return true;
return false;
}
public int GetHashCode(teamDetails obj)
{
if (Object.ReferenceEquals(obj, null)) return 0;
return obj.teamName.GetHashCode();
}
}
答案 1 :(得分:1)
你可以简单地使用这个
SearchCheckedListBox.DataSource = viewList.GroupBy(x => x.teamName)
.Select(g => g.First())
.ToList();
如果您计划多次使用相同的技巧,可以编写扩展方法
public static IEnumerable<T> DistinctBy<T, S>(this IEnumerable<T> list, Func<T, S> selector)
{
return list.GroupBy(selector).Select(g => g.First());
}
那么代码就是
SearchCheckedListBox.DataSource = viewList.DistinctBy(x => x.teamName).ToList();