我有一个包含许多行的文本文件,如下所示:
鲜花{郁金香|太阳花|玫瑰}
性别{女|男}
宠物猫{|狗|兔}
我知道如何从文件中读取行,但是之后将类别及其子项拆分并存储在字典中的最佳方法是什么?让我们说一个包含所有上述行的字符串数组?
答案 0 :(得分:3)
使用正则表达式的想法是正确的,但我更喜欢使用命名捕获来提高可读性
var regexp = new Regex(@"(?<category>\w+?)\{(?<entities>.*?)\}");
var d = new Dictionary<string, List<string>>();
// you would replace this list with the lines read from the file
var list = new string[] {"Flowers{Tulip|Sun Flower|Rose}"
, " Gender{Female|Male}"
, "Pets{Cat|Dog|Rabbit}"};
foreach (var entry in list)
{
var mc = regexp.Matches(entry);
foreach (Match m in mc)
{
d.Add(m.Groups["category"].Value
, m.Groups["entities"].Value.Split('|').ToList());
}
}
您将获得一个字典,其中类别为键,字符串列表中的值为
答案 1 :(得分:1)
您可以在此代码上使用Key
和value
string T = @"Flowers{Tulip|Sun Flower|Rose}
Gender{Female|Male}
Pets{Cat|Dog|Rabbit}";
foreach (var line in T.Split('\n'))//or while(!file.EndOfFile)
{
var S = line.Split(new char[] { '{', '|','}' }, StringSplitOptions.RemoveEmptyEntries);
string Key = S[0];
MessageBox.Show(Key);//sth like this
for (int i = 1 ; i < S.Length; i++)
{
string value = S[i];
MessageBox.Show(value);//sth like this
}
}
答案 2 :(得分:0)
你可以用这个:
string line = reader.ReadLine();
Regex r = new Regex(@"(\w+){(\w+)}");
现在循环此正则表达式的结果:
foreach(Match m in r.Matches(line)) {
yourDict.Add(m.Groups[1], m.Groups[2].Split(' '));
}