将节点保存到另一个文件xml Windows phone 7

时间:2012-05-08 15:36:53

标签: c# xml windows-phone-7

我有一个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));
    }
}

如何获得&lt; 1_Data_Lv2_1&gt;的所有节点lv1? ==“A1”并写入另一个xml?

1 个答案:

答案 0 :(得分:1)

发布的XML无效,因为节点无法以数字开头,即1_Data_Lv2_1应为One_Data_Lv2_12_Data_Lv2_1应为Two_Data_Lv2_1

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

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>