我有一个多次迭代的列表。它将rangename作为项目。我的要求是当此列表的任何索引处的rangename等于某个其他索引处的rangename时执行操作。我使用以下代码。
var bList = new List<Budget.budget_data>();
for (int z = 0; z < bList.Count; z++)
{
if (bList [z].Range == bList.Where(a => bList.Any(x => x.Range ==x.Range)))
{
//need to perform action
}
}
给出了错误。如何将列表项的一个索引值与同一列表中的所有索引进行比较。
答案 0 :(得分:0)
我觉得不太清楚,但你可以试试这个:
var bList = new List<Budget.budget_data>();
// ...
var z = ...;
for (var x = 0; x < bList.Count; ++x)
{
if (x == z)
continue;
if (bList[z].Range == bList[x].Range)
{
//need to perform action
}
}
对于存在匹配项的每个索引x
执行一次操作,因此该操作可以多次运行。如果您只想执行一次操作,则可以使用if
语句完成break;
块(完全退出循环)。
注意:这假设.Range
的类型使用==
是合理的。声明的.Range
类型是什么?
我可能误解了这个问题。如果您想确定是否有任何重复项,您可以:
var bList = new List<Budget.budget_data>();
// ...
var uniqueRangeValues = new HashSet<string>();
foreach (var b in bList)
{
if (!uniqueRangeValues.Add(b.Ranges))
{
// perform action
break; // omit if you want to perform the action several times
}
}
答案 1 :(得分:0)
根据我的理解,您希望在列表中两个范围相等时执行某些操作。以下应该适合你。
var bList = new List<Budget.budget_data>();
for (var i = 0; i < bList.Count; i++)
{
for (var j = i + 1; j < bList.Count; j++)
{
if (bList[i].Range == bList[j].Range)
{
//Perform your action
}
}
}
如果列表中有任何重复的范围,则会执行此操作。
答案 2 :(得分:0)
听起来你正在试图找到重复的内容,但却没有清楚地知道你想要实现什么,很难帮助你找到适合你问题的解决方案。
使用您提供的一些细节,下面是循环重复的通用解决方案。
public static void Main()
{
var budgets = new List<Budget>()
{
new Budget(){ Id = 1, Range = "A" },
new Budget(){ Id = 2, Range = "B" },
new Budget(){ Id = 3, Range = "C" },
new Budget(){ Id = 4, Range = "C" },
new Budget(){ Id = 5, Range = "A" }
};
var duplicateBudgetGroups = budgets.GroupBy(budget => budget.Range).Where(group => group.Count() > 1);
foreach (var duplicateBudgets in duplicateBudgetGroups)
{
Console.WriteLine("Duplicate Range {0}", duplicateBudgets.Key);
foreach (var budget in duplicateBudgets)
{
Console.WriteLine("Budget {{ Id = {0}, Range = {1} }}", budget.Id.ToString(), budget.Range);
}
}
}
class Budget {
public int Id { get; set; }
public string Range { get; set; }
}
我已将此添加到dotnetfiddle中,因此您可以看到它正常工作:https://dotnetfiddle.net/65gF6f