0

linq to xmlを使用して、ノードの名前とそれに対応する値をxmlファイルで取得したいと思います。

私は通常、このコード行を実行してノードの値を取得し、それをリストに格納します

var qry = from c in XElement.Load(commonpath).Elements("Root") select c;

        List<string> result = new List<string>();
        foreach (var i in qry)
        {
            result.Add(Convert.ToString(i));
        }

しかし今、私はノード名と値の両方がそれを辞書に保存したい

Dictionary<string, double> amount = new Dictionary<string, double>();
        var qry = "";//what query here
        foreach(var i in qry)
        {
            amount.Add("Node Name", "Value");
        }

したがって、この状況に対する正しいクエリは何ですか。助けてください。ありがとう

4

1 に答える 1

1

これがあなたが探しているものであることを願っています:

    var doc = XDocument.Parse(@"
         <root>
            <firstname>Lucas</firstname>
            <lastname>Ontivero</lastname>
         </root>");
    var qry = from element in doc.Element("root").Descendants() select element;
    var result = qry.ToDictionary(e => e.Name, e => e.Value);
    result.ToList().ForEach(x=> Console.WriteLine("{0}:{1}", x.Key, x.Value ));

それは印刷します:

  ファーストネーム:ルーカス
  姓:オンティベロ

役に立つかどうか教えてください。幸運を!

于 2012-12-08T03:00:30.680 に答える