I got a string like A:<<Default>>;B:<<Default>>;C:<<Default>>;D:<<Default>>;E:<<Default>>[pattern string]
The string representation is similar to a dictionary key: A value that is grouped as a comma delimited string.
Now, after applying the logic, I get a list of lines below,
A:aaa;E:eee
D:ddd
B:bbb;E:eee
Now I need to do the above list below (where the key with the new value should be placed in the correct order and have the rest of the keys with default values),
A:aaa;B:<<Default>>;C:<<Default>>;D:<<Default>>;E:eee
A:<<Default>>;B:<<Default>>;C:<<Default>>;D:ddd;E:<<Default>>
A:<<Default>>;B:bbb;C:<<Default>>;D:<<Default>>;E:eee
Tried with split function, Replace and convert to list to achieve this. Do we have an effective way to achieve the same?
string constants = "A:<<Default>>;B:<<Default>>;C:<<Default>>;D:<<Default>>;E:<<Default>>";
string placeHolder = string.Empty;
List<string> filteredkeys = new List<string>();
List<string> formattedKeys = new List<string>();
filteredkeys.Add("A:aaa;E:eee;");
filteredkeys.Add("D:ddd;");
filteredkeys.Add("B:bbb;E:eee;");
foreach (var item in filteredkeys)
{
placeHolder = constants;
List<string> keyCombination = item.TrimEnd(';').Split(';').ToList();
foreach (string keys in keyCombination)
{
List<string> abc = keys.Split(':').ToList();
switch (abc[0])
{
case "A":
placeHolder = placeHolder.Replace("A:<<Default>>", keys);
break;
case "B":
placeHolder = placeHolder.Replace("B:<<Default>>", keys);
break;
case "C":
placeHolder = placeHolder.Replace("C:<<Default>>", keys);
break;
case "D":
placeHolder = placeHolder.Replace("D:<<Default>>", keys);
break;
case "E":
placeHolder = placeHolder.Replace("D:<<Default>>", keys);
break;
}
}
formattedKeys.Add(placeHolder);
}
source
share