0

我有一个 XML 文件:

<Root>
     <Lv1>
          <1_Data_Lv2_1>A1</1_Data_Lv2_1>
          <2_Data_Lv2_1>A2</2_Data_Lv2_1>
     </Lv1>
     <Lv1>
          <1_Data_Lv2_1>B1</1_Data_Lv2_1>
          <2_Data_Lv2_1>B2</2_Data_Lv2_1>
     </Lv1>
</Root>

C#

using (var myStream = new IsolatedStorageFileStream("Settings.xml", FileMode.Open, myIsolatedStorage))
{
    xdoc = XDocument.Load(myStream);
} 

var lv1s = from lv1 in xdoc.Elements("Root")
           select new
           {
               Children = lv1.Descendants("Lv1")
           };

foreach (var lv1 in lv1s)
{
    foreach (var lv2 in lv1.Children)
    {
        MessageBox.Show(Convert.ToString(lv2.Value));
    }
}

如何获取 <1_Data_Lv2_1> == "A1" 的所有节点 lv1 并写入另一个 xml?

4

1 回答 1

1

发布的 XML 无效,因为节点不能以数字开头,即1_Data_Lv2_1应该是One_Data_Lv2_1并且2_Data_Lv2_1应该是Two_Data_Lv2_1

进行更改后,您可以找到One_Data_Lv2_1值为 A1 的所有节点:

var doc = XDocument.Load( myStream );
// find all descendant nodes with a value of A1
var a1s = doc.Root.Descendants( "One_Data_Lv2_1" )
                 .Where( x => x.Value == "A1" )

foreach( XElement e in a1s )
{
    Debug.WriteLine( e.Value );
}

要将查询结果添加到新的 XML 文档:

var doc2 = new XDocument();
var root = new XElement("Root");
var lvl = new XElement( "LvlNew" );
// adding the a1s collection to the lvl node
lvl.Add( a1s );
root.Add( lvl );
doc2.Add( root );

看起来像:

<Root>
  <LvlNew>
    <One_Data_Lv2_1>A1</One_Data_Lv2_1>
  </LvlNew>
</Root>
于 2012-05-08T23:42:39.667 回答