Читать XML (из строки) и получить некоторые поля - Проблемы с чтением XML - PullRequest
70 голосов
/ 06 декабря 2011

У меня есть этот XML (хранится в строке C # с именем myXML)

<?xml version="1.0" encoding="utf-16"?>
<myDataz xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
  <listS>
    <sog>
      <field1>123</field1>
      <field2>a</field2>
      <field3>b</field3>
    </sog>
    <sog>
      <field1>456</field1>
      <field2>c</field2>
      <field3>d</field3>
    </sog>
  </listS>
</myDataz>

и я бы хотел просмотреть все <sog> элементы. Для каждого из них я хотел бы напечатать ребенка <field1>.

Так вот мой код:

XmlDocument xmlDoc = new XmlDocument();
string myXML = "<?xml version=\"1.0\" encoding=\"utf-16\"?><myDataz xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" xmlns:xsd=\"http://www.w3.org/2001/XMLSchema\"><listS><sog><field1>123</field1><field2>a</field2><field3>b</field3></sog><sog><field1>456</field1><field2>c</field2><field3>d</field3></sog></listS></myDataz>"
xmlDoc.Load(myXML);
XmlNodeList parentNode = xmlDoc.GetElementsByTagName("listS");
foreach (XmlNode childrenNode in parentNode)
{
    HttpContext.Current.Response.Write(childrenNode.SelectSingleNode("//field1").Value);
}

но, кажется, я не могу прочитать строку как XML? Я получаю System.ArgumentException

Ответы [ 5 ]

95 голосов
/ 06 декабря 2011

Вы должны использовать метод LoadXml, а не Load:

xmlDoc.LoadXml(myXML); 

Метод Load пытается загрузить xml из файла и LoadXml из строки. Вы также можете использовать XPath:

XmlDocument xmlDoc = new XmlDocument();
xmlDoc.LoadXml(xml);

string xpath = "myDataz/listS/sog";
var nodes = xmlDoc.SelectNodes(xpath);

foreach (XmlNode childrenNode in nodes)
{
    HttpContext.Current.Response.Write(childrenNode.SelectSingleNode("//field1").Value);
} 
17 голосов
/ 06 декабря 2011

Использовать Linq-XML,

XDocument doc = XDocument.Load(file);

var result = from ele in doc.Descendants("sog")
              select new
              {
                 field1 = (string)ele.Element("field1")
              };
 foreach (var t in result)
  {
      HttpContext.Current.Response.Write(t.field1);
  }

ИЛИ: получить список узлов тега <sog>.

 XmlDocument xmlDoc = new XmlDocument();
 xmlDoc.Load(myXML);
 XmlNodeList parentNode = xmlDoc.GetElementsByTagName("sog");
 foreach (XmlNode childrenNode in parentNode)
  {
    HttpContext.Current.Response.Write(childrenNode.SelectSingleNode("field1").InnerText);
   }
9 голосов
/ 06 сентября 2015

Другим ответам уже несколько лет (и они не работают для Windows Phone 8.1), поэтому я решил добавить другой вариант.Я использовал это для разбора ответа RSS для приложения Windows Phone:

XDocument xdoc = new XDocument();
xdoc = XDocument.Parse(xml_string);
3 голосов
/ 06 декабря 2011

Или используйте класс XmlSerializer.

XmlSerializer xs = new XmlSerializer(objectType);
obj = xs.Deserialize(new StringReader(yourXmlString));
2 голосов
/ 01 июня 2016

Я использовал System.Xml.Linq.XElement для этой цели. Просто проверьте код ниже для чтения значения первого дочернего узла xml (не корневого узла).

        string textXml = "<xmlroot><firstchild>value of first child</firstchild>........</xmlroot>";
        XElement xmlroot = XElement.Parse(textXml);
        string firstNodeContent = ((System.Xml.Linq.XElement)(xmlroot.FirstNode)).Value;
...