我正在尝试将XML字符串解析为列表,结果计数始终为零.
string result = "";
string address = "http://www.ecb.europa.eu/stats/eurofxref/eurofxref-daily.xml";
// Create the web request
HttpWebRequest request = WebRequest.Create(address) as HttpWebRequest;
// Get response
using (HttpWebResponse response = request.GetResponse() as HttpWebResponse)
{
// Get the response stream
StreamReader reader = new StreamReader(response.GetResponseStream());
// Read the whole contents and return as a string
result = reader.ReadToEnd();
}
XDocument doc = XDocument.Parse(result);
var ListCurr = doc.Descendants("Cube").Select(curr => new CurrencyType()
{ Name = curr.Element("currency").Value, Value = float.Parse(curr.Element("rate").Value) }).ToList();
Run Code Online (Sandbox Code Playgroud)
哪里出错了
问题是你正在寻找没有命名空间的元素,而XML在根元素中包含这个元素:
xmlns="http://www.ecb.int/vocabulary/2002-08-01/eurofxref"
Run Code Online (Sandbox Code Playgroud)
这指定了任何元素的默认命名空间.此外,currency和rate是属性的内部Cube元素-它们不是子元素.
所以你想要这样的东西:
XNamespace ns = "http://www.ecb.int/vocabulary/2002-08-01/eurofxref";
var currencies = doc.Descendants(ns + "Cube")
.Select(c => new CurrencyType {
Name = (string) c.Attribute("currency"),
Value = (decimal) c.Attribute("rate")
})
.ToList();
Run Code Online (Sandbox Code Playgroud)
请注意,因为我正在将currency属性转换为string,Name所以对于未指定该属性的任何货币,您最终将使用null 属性.如果你想跳过这些元素,你可以Where在之前或之后使用一个子句Select.
另外请注意,我已经改变了类型Value来decimal而不是float-你不应该使用float货币相关的值.(有关详细信息,请参阅此问题.)
此外,您应该考虑使用XDocument.Load加载XML:
XDocument doc = XDocument.Load(address);
Run Code Online (Sandbox Code Playgroud)
然后就没有必要自己创建WebRequest等.
| 归档时间: |
|
| 查看次数: |
3072 次 |
| 最近记录: |