繁体   English   中英

C#从xml文件获取值

[英]C# Getting values from xml file

我正在尝试从xml文件中获取纬度(lat)和经度(lon)值。

XML文件是使用以下代码通过Web请求生成的。

var request = WebRequest.Create("#") as HttpWebRequest;
request.Credentials = new System.Net.NetworkCredential("#", "#");
var response = request.GetResponse();
Stream receiveStream = response.GetResponseStream();
StreamReader readStream = new StreamReader(receiveStream, Encoding.UTF8);
var result = readStream.ReadToEnd();
String xmlString = result;
System.Xml.XmlTextReader reader = new System.Xml.XmlTextReader(new System.IO.StringReader(xmlString));
reader.Read();
System.Data.DataSet ds = new System.Data.DataSet();
ds.ReadXml(reader, System.Data.XmlReadMode.Auto);
DataTable dt = ds.Tables[0];
lbllat.Text = dt.Rows[0][5].ToString();//for example 
lbllong.Text = dt.Rows[0][6].ToString();

但是代码给出了以下错误消息。

错误:“>”是意外​​令牌。 预期令牌为“ =”。 第2行,位置483

主要是因为XML标记不接受空格而发生错误。

生成的xml文件格式。

<?xml version="1.0"?>
<root>
  <code>0</code>
  <msg>OK</msg>
  <data>
    <agentid>1</agentid>
    <imei>3224</imei>
    <typeid>2</typeid>
    <type>Truck</type>
    <vehiclenumber>12121</vehiclenumber>
    <folder>folder1</folder>
    <created_time>1493813160</created_time>
    <current_mileage>4232</current_mileage>
    <status>
      <active>1</active>
      <speed>0</speed>
      <direction>303</direction>
      <lat>3.79092</lat>
      <lon>69.51279</lon>
      <alt>1</alt>
      <satsinview>18</satsinview>
      <unixtimestamp>1503389638</unixtimestamp>
      <sensors>
        <Ignition sensor="">Off</Ignition sensor><External power="" supply="">On</External power supply>
      </sensors>
    </status>
  </data>
</root>

有什么建议么 ?

首先,修复XML,但如果不能,则使用HTML Agility Pack检索格式错误的XML。 对于网络抓取和处理格式错误的XML来说,这非常好。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM