Прочтите XML (из строки) и получите несколько полей - Проблемы с чтением XML


83

У меня есть этот 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


2
Что говорит исключение ?
SLaks 06

Можете ли вы использовать XDocument в .NET 4.0?
JohnD

Я использую .NET 3.5! Я написал исключение!
markzzz 06

1
Что такое сообщение об исключении ?
SLaks 06

XLINQ полностью поддерживается в .Net 3.5 и намного проще в использовании.
SLaks 06

Ответы:


109

Вы должны использовать метод 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);
} 

Потрясающе просто. Наконец-то я могу начать работать с API :).
C4d

7
Вместо SelectSingleNode("//field1").Valueнего должно быть SelectSingleNode("//field1").InnerTextили SelectSingleNode("//field1").InnerXml, потому что Value будет иметь значение null, поскольку это не атрибут, а значение находится между тегами.
Матиас Конрад

3
Чтобы добавить в @MathiasConradt, это должно быть, SelectSingleNode("field1").InnerTextесли вы не хотите всегда читать field1первое появление myDataz / listS / sog.
Matthieu M.

19

Используйте 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);
   }

11

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

XDocument xdoc = new XDocument();
xdoc = XDocument.Parse(xml_string);

3

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

XmlSerializer xs = new XmlSerializer(objectType);
obj = xs.Deserialize(new StringReader(yourXmlString));

2

Для этой цели я использовал 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;
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.