<?xml-stylesheet href="latest_ob.xsl" type="text/xsl"?>
<current_observation version="1.0" >
</image>
<suggested_pickup>15 minutes after the hour</suggested_pickup>
<suggested_pickup_period>60</suggested_pickup_period>
<temp_f>44.0</temp_f>
<temp_c>6.7</temp_c>
<relative_humidity>55</relative_humidity>
<wind_string>North at 6.9 MPH (6 KT)</wind_string>
<wind_dir>North</wind_dir>
<wind_degrees>340</wind_degrees>
<wind_mph>6.9</wind_mph>
<wind_kt>6</wind_kt>
<pressure_string>1025.2 mb</pressure_string>
<pressure_mb>1025.2</pressure_mb>
<pressure_in>30.28</pressure_in>
<dewpoint_string>28.9 F (-1.7 C)</dewpoint_string>
<dewpoint_f>28.9</dewpoint_f>
<dewpoint_c>-1.7</dewpoint_c>
</current_observation>我想从上面的xml数据中获取一些属性,比如wind_dir、wind_kt等。我已经尝试过了:
var dayt = GetXMLAsString(WeatherXML);
XDocument doc = XDocument.Parse(dayt);
var r = from element in doc.Elements()
where element.Name == "latitude"
select element;
foreach (var item in r)
{
Console.WriteLine(item.Value);
}我希望将此数据转换为数组或模型,以便将其发送到ajax结果。
发布于 2017-11-01 19:56:11
我之前试过了,但还是保留了".value":
var a= from hash in doc.Descendants("latitude") select hash.value;
当我尝试的时候,我得到了正确的结果: XmlDocument WeatherXML =新的XmlDocument();WeatherXML.Load(阅读器);
var dayt = GetXMLAsString(WeatherXML);
XDocument doc = XDocument.Parse(dayt);var = from hash in doc.Descendants("latitude") select hash;
var asdd = from hash in doc.Descendants("current_observation")
select hash;发布于 2017-11-01 20:19:38
通过使用System.Xml.Linq名称空间,我们可以调用一组方便的方法。在您的情况下,以下代码会有所帮助:
var doc = XDocument.Parse(WeatherXML);
var value = from e in doc.Elements()
where e.Name == "wind_kt"
select e.Value;https://stackoverflow.com/questions/47053892
复制相似问题