簡體   English   中英

Windows Phone中的XML解析

[英]XML Parsing in windows phone

我必須解析XML,因為使用了一些可以正常工作的代碼,但是問題不是我們嵌套了XML,所以該代碼無法解析所有數據。所以請建議我如何分解。

XML格式

<Author>
  <Book id="101" name="Computer" subcategories="2">
    <Book id="600" name="java" subcategories="0" contents="10 books"/>
    <Book id="601" name="php" subcategories="0" contents="5 books"/>
  </Book>
  <Book id="201" name="Language" subcategories="2">
    <Book id="700" name="Hindi" subcategories="0" contents="6 books"/>
    <Book id="701" name="English" subcategories="0" contents="4 books"/>
  </Book>
  <Book id="301" name="Music" subcategories="2">
    <Book id="800" name="life" subcategories="0" contents="10 books"/>
    <Book id="801" name="Wild" subcategories="0" contents="5 books"/>
  </Book>
  <Book id="401" name="Story" subcategories="2">
    <Book id="900" name="My Life" subcategories="0" contents="1 books"/>
    <Book id="901" name="One Day" subcategories="0" contents="1 books"/>
  </Book>
</Author>

解析器方法:

public void parser()
        {
            XElement nodes = XElement.Load("file.xml");

            var node = from nd in nodes.DescendantNodes() select nd;

            foreach (XElement nds in node)
            {
                string name = nds.Attribute("name").Value;
                int id=Convert.ToInt32(nds.Attribute("id").Value);
                MessageBox.Show("" + name);
                MessageBox.Show("" + id);
                if (nds.HasElements)
                {
                     getChild(nds.DescendantNodes(),id);
                }

            }
 public void getChild(IEnumerable<XNode> node,int id)
        {

            foreach (XElement nds in node)
            {


                IEnumerable<XNode> nd=from list in nds.DescendantNodes() select list;
                int temp = Convert.ToInt32(ids);



                    foreach (XElement ss in nd)
                    {
                        string name = ss.Attribute("name").Value;
                        MessageBox.Show("" + name);
                    }

                if (nds.HasElements)
                {
                    getChild(nds.DescendantNodes(),id);
                }
            }
        }

我具有上述XML,並已使用上述代碼進行解析。

也許您正在尋找:

XElement doc = XElement.Parse(@"<Author>
                                  <Book id=""101"" name=""Computer"" subcategories=""2"">
                                    <Book id=""600"" name=""java"" subcategories=""0"" contents=""10 books""/>
                                    <Book id=""601"" name=""php"" subcategories=""0"" contents=""5 books""/>
                                  </Book>
                                  <Book id=""201"" name=""Language"" subcategories=""2"">
                                    <Book id=""700"" name=""Hindi"" subcategories=""0"" contents=""6 books""/>
                                    <Book id=""701"" name=""English"" subcategories=""0"" contents=""4 books""/>
                                  </Book>
                                  <Book id=""301"" name=""Music"" subcategories=""2"">
                                    <Book id=""800"" name=""life"" subcategories=""0"" contents=""10 books""/>
                                    <Book id=""801"" name=""Wild"" subcategories=""0"" contents=""5 books""/>
                                  </Book>
                                  <Book id=""401"" name=""Story"" subcategories=""2"">
                                    <Book id=""900"" name=""My Life"" subcategories=""0"" contents=""1 books""/>
                                    <Book id=""901"" name=""One Day"" subcategories=""0"" contents=""1 books""/>
                                  </Book>
                                </Author>");
var query = doc.Descendants();
foreach(XElement ele in query){
    Console.WriteLine(string.Format("Name: {0}\nValue: {1}\n",ele.Name.LocalName.ToString(),ele));
    if (ele.HasAttributes){
        var query1 = ele.Attributes();
        foreach (XAttribute att in query1)
        {
            Console.WriteLine(string.Format("Attribute: {0}\nValue: {1}\n", att.Name.LocalName.ToString(), att.Value));
        };
    };
};

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM