如何在Windows Phone 7中解析XML(DataSet)

时间:2011-12-29 15:35:17

标签: windows-phone-7 xml-serialization

我有一个像下面的XML,但我无法解析它。请帮我解析下面的XML。

<?xml version="1.0" encoding="utf-8"?><soap:Envelope     
xmlns:soap="http://www.w3.org/2003/05/soap-envelope"     
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"     
xmlns:xsd="http://www.w3.org/2001/XMLSchema"><soap:Body>
<GetResponse xmlns="http://tempuri.org/"><GetResult>
<diffgr:diffgram xmlns:msdata="urn:schemas-microsoft-com:xml-msdata" xmlns:diffgr="urn:schemas-microsoft-com:xml-diffgram-v1">
<NewDataSet xmlns="">
<Table diffgr:id="Table1" msdata:rowOrder="0">
<a>hi1</a>
<b>hi2</b>
</Table>
<Table diffgr:id="Table2" msdata:rowOrder="1">
<a>hi3</a>
<b>hi4</b>
</Table>
</NewDataSet>
</diffgr:diffgram>
</GetResponse></GetResult>
</soap:Body>
</soap:Envelope>

这里我想要表格(即a,b)标签的结果。我尝试使用Linq,但我无法解析它。我尝试了这样的代码:

//XML will be there in response string
String response = e.response;
public static String myNamespace = "http://tempuri.org/";
XDocument reader = XDocument.Parse(response);
var results = from result in reader.Descendants(XName.Get("GetResponse", myNamespace))
              select result.Element("GetResult").

但是这段代码返回null。

修改 我使用下面的代码: 字符串响应= e.response;

public static String myNamespace = "http://tempuri.org/";
XDocument reader = XDocument.Parse(response);
XElement resultElement = reader.Descendants(XName.Get("GetResult", myNamespace)).Single(); 
XElement resultElement1 = resultElement.Descendants(XName.Get("NewDataSet", "")).Single();

所以现在resultElement1我得到了如下的XML:

<NewDataSet xmlns="">
  <Table diffgr:id="Table1" msdata:rowOrder="0" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata" xmlns:diffgr="urn:schemas-microsoft-com:xml-diffgram-v1">
<a>hi1</a>
<b>hi2</b>
</Table>
<Table diffgr:id="Table2" msdata:rowOrder="1" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata" xmlns:diffgr="urn:schemas-microsoft-com:xml-diffgram-v1">
<a>hi3</a>
<b>hi4</b>
</Table>
</NewDataSet>

那么现在我如何才能找到tag和tag的值?

提前致谢。

2 个答案:

答案 0 :(得分:1)

什么阻挡了你?

你可以试试这个:

        var resultNewDataSet = XElement.Parse(xmlContent);

        var result = resultNewDataSet.Descendants("Table")
            .Select(t => new
                {
                    aaa = t.Descendants("aaa").First().Value,
                    bbb = t.Descendants("bbb").First().Value
                });

        foreach (var res in result)
        {
            System.Diagnostics.Debug.WriteLine("aaa: " + res.aaa + " / bbb: " + res.bbb);
        }

答案 1 :(得分:0)

元素GetResult也在http://tempuri.org命名空间中,因此这就是你选择子句没有找到任何东西的原因。

无论如何,我会将查询简化为以下内容:

public static String myNamespace = "http://tempuri.org/";
XDocument reader = XDocument.Parse(response);
XElement resultElement = reader.Descendants(XName.Get("GetResult", myNamespace)).Single();