Список <KeyValuePair>переопределяет добавленные значения - PullRequest
0 голосов
/ 16 апреля 2020

В настоящее время я сталкиваюсь с проблемой, когда я хочу добавить разные значения к одному и тому же ключу через foreach l oop.

List<KeyValuePair<string, Dictionary<string, string>>> sysList = new List<KeyValuePair<string, Dictionary<string, string>>>();
Dictionary<string, string> newSystem = new Dictionary<string, string>();
string line1="";
string line2="";
string quit="";
foreach(Worksheet ws in workbook.Worksheets)
{
     while(quit != q)
     {
        newSystem.Clear();
        line1 = Console.ReadLine();
        line2 = Console.ReadLine();
        quit = Console.ReadLine();
     }
     newSystem.Add(line1, line2);
     sysList.Add(new KeyValuePair<string, Dictionary<string, string>>(ws.Name,newSystem));
}

Для первой итерации (в течение времени) первого рабочего листа ws все хорошо. Если я решу сделать> 1 итераций на этом рабочем листе, будет добавлена ​​новая запись, но значения словаря все те же, например:

syList[0]: "worksheetName","test1","test2"
syList[1]: "worksheetName","test1","test2"
syList[2]: "worksheetName","test1","test2"

Если есть несколько итераций foreach, имена остаются то же самое, но ключ и значения словаря, добавленные newSys, одинаковы [ПОСЛЕ второй итерации foreach]:

syList[0]: "worksheetName1","test1","test2"
syList[1]: "worksheetName1","test1","test2"
syList[2]: "worksheetName1","test1","test2"
syList[3]: "worksheetName2","test1","test2"
syList[4]: "worksheetName2","test1","test2"

Изначально я пытался использовать словари, но не мог правильно обрабатывать те же ключи и не нашел правильное решение за исключением использования List.

Я очень благодарен за любую предоставленную помощь. Если вам нужны дополнительные сведения, пожалуйста, сообщите мне.

Редактировать: желаемый результат (пример):

#########:         ws.Name, line1,   line2
syList[0]: "worksheetName1","ABC","1"
syList[1]: "worksheetName1","DEF","2"
syList[2]: "worksheetName1","ABC","5"
syList[3]: "worksheetName2","ABD","4"
syList[4]: "worksheetName2","ZZZ","1"

Ответы [ 2 ]

1 голос
/ 16 апреля 2020

Если вы не хотите сохранять уникальность ключей и просто хотите получить плоский список, вы можете использовать синтаксис кортежа C # 7 для создания списка.

List<string> sheetNames = new List<string>() { "worksheetName1", "worksheetName2" };
var sysList = new List<(string SheetName, string line1, string line2)>();

string line1 = string.Empty; 
string line2 = string.Empty; 
string quit = string.Empty;

foreach (var sheet in sheetNames)
{
    while (quit != "E")
    {
        line1 = Console.ReadLine();
        line2 = Console.ReadLine();
        quit = Console.ReadLine();

        sysList.Add((sheet, line1, line2));
    }
    quit = string.Empty;
}
1 голос
/ 16 апреля 2020

Попробуйте код ниже:

List<List<string>> syList =  new List<List<string>>() {
                                new List<string>() {"worksheetName1","test1","test2"},
                                new List<string>() {"worksheetName1","test1","test2"},
                                new List<string>() {"worksheetName1","test1","test2"},
                                new List<string>() {"worksheetName2","test1","test2"},
                                new List<string>() {"worksheetName2","test1","test2"}
                    };
 Dictionary<string, Dictionary<string, List<string>>> dict = syList
    .GroupBy(x => x.First(), y => y)
        .ToDictionary(x => x.Key, y => y
            .GroupBy(a => a.Skip(1).FirstOrDefault(), b => b.Last())
            .ToDictionary(a => a.Key, b => b.ToList()));


//using normal looping
 Dictionary<string, Dictionary<string, List<string>>> dict2 = new Dictionary<string, Dictionary<string, List<string>>>();

 foreach (List<string> sy in syList)
 {
     if (dict2.ContainsKey(sy[0]))
     {
         Dictionary<string, List<string>> tempDict = dict2[sy[0]];
         if (tempDict.ContainsKey(sy[1]))
         {
             tempDict[sy[1]].Add(sy[2]);
         }
         else
         {
             List<string> newList = new List<string>() { sy[2] };
             tempDict.Add(sy[1], newList);

         }
     }
     else
     {
         Dictionary<string, List<string>> newDict = new Dictionary<string, List<string>>();
         newDict.Add(sy[1], new List<string> { sy[2] });
         dict2.Add(sy[0], newDict);

     }
 }
...