Я хотел бы отметить, что XmlTextReader is basically replaced with XmlReader:
Начиная с .NET Framework 2.0, мы рекомендуем использовать класс System.Xml.XmlReader .
Хотя их объектная модель не имеет значительного различия.
Итак, если вы хотите использовать XmlTextReader вы можете сделать что-то вроде:
public static class XmlReaderExtensions
{
public static void EnsureRead(this XmlTextReader reader)
{
var isRead = reader.Read();
if (!isRead)
throw new InvalidOperationException("Failed to read");
}
public static void SkipUntil(this XmlTextReader reader, Func<XmlTextReader, Boolean> isStop)
{
while (!isStop(reader))
{
reader.EnsureRead();
}
}
}
...
var xml = @"<root> <key>businessAddress</key>
<string>Moka</string>
<key>businessName</key>
<string>Moka address</string>
<key>Id</key>
<string>39</string>
<key>Cat</key>
<string>216</string>
<key>deals</key> </root>";
using (var stream = new MemoryStream(Encoding.Default.GetBytes(xml)))
using (var reader = new XmlTextReader(stream))
{
reader.SkipUntil(cur => cur.Value == "Id");
reader.EnsureRead(); // Skip current node
reader.SkipUntil(cur => cur.NodeType == XmlNodeType.Text);
Console.WriteLine("The id from XmlTextReader is {0}", reader.Value);
}
Хотя, чтобы быть уверенным, что он будет работать корректно неудачу быстро с некоторыми xml, который не соответствует данной схеме, вам придется добавить немного больше проверок работоспособности, поэтому ...
Вы также можете попробовать LINQ-TO-XML если вы не связаны с всем XML-дерево ввода в память:
using (var stream = new MemoryStream(Encoding.Default.GetBytes(xml)))
{
var xdoc = XDocument.Load(stream);
var id = xdoc
.Root
.Elements("key")
.First(element =>
element.Value == "Id")
.ElementsAfterSelf("string")
.First()
.Value;
Console.WriteLine("The id from XDocument is {0}", id);
}