Лучший способ прочитать xml
HI У меня есть xml-документ, например:
<Students>
<student name="A" class="1"/>
<student name="B"class="2"/>
<student name="c" class="3"/>
</Students>
Я хочу использовать XmlReader
для чтения этого xml и вернуть список студентов как List<student>
.
Я знаю, что это может быть достигнуто следующим образом:
List<Student> students = new List<Student>();
XmlReader reader = XmlReader.Create("AppManifest.xml");
while (reader.Read())
{
if (reader.NodeType == XmlNodeType.Element && reader.Name == "student")
{
students.Add(new Student()
{
Name = reader.GetAttribute("name"),
Class = reader.GetAttribute("Class")
});
}
}
Я просто хочу знать, есть ли лучшее решение для этого?
Я использую silverlight 4. Структура xml является статической, т.е. он будет иметь только один Students
node, и все ученики node с указанными выше атрибутами будут только там.
Ответы
Ответ 1
Абсолютно - используйте LINQ to XML. Это намного проще:
XDocument doc = XDocument.Load("AppManifest.xml");
var students = doc.Root
.Elements("student")
.Select(x => new Student {
Name = (string) x.Attribute("name"),
Class = (string) x.Attribute("class")
})
.ToList();
XmlReader
является относительно низкоуровневым типом - я бы избегал его, если вы действительно не можете позволить себе весь XML в память за раз. Даже тогда есть способы использования LINQ to XML в сочетании с XmlReader
, если вы просто хотите поддеревья документа.
Ответ 2
Это намного проще, если мы используем Linq xml:
var xDoc = XDocument.Load("AppManifest.xml");
var students =
xDoc.Root.Elements("student")
.Select(n =>
new Student
{
Name = (string)n.Attribute("name"),
Class = (string)n.Attribute("class"),
})
.ToList();
Ответ 3
List<Student> students = (from student in doc.Element("Students").Elements("student")
select new Student {
Name = student.Attribute("name"),
Class = student.Attribute("class") }
).ToList();
Ответ 4
Обратитесь к ссылке ниже,
http://www.nearinfinity.com/blogs/joe_ferner/performance_linq_to_sql_vs.html
XmlReader
поддерживается в Silverlight
(http://msdn.microsoft.com/en-us/library/cc189001(v=vs.95).aspx)
XmlReader
как a SQLDataReader
в основном не кэшированная модель, поэтому они ориентированы на производительность, но вы можете перемещать только "вперед" с этим.
Ответ 5
Вы можете использовать так:
protected void Page_Load(object sender, EventArgs e)
{
XmlTextReader reader = new XmlTextReader(Server.MapPath("~/XML"));
while(reader.Read())
{
switch(reader.NodeType)
{
case XmlNodeType.Element:
var lbl = new Label();
lbl.Text=(reader.Name + " -> " );
break;
case XmlNodeType.Text:
Response.Write(reader.Value + "<br />");
break;
case XmlNodeType.EndElement:
Response.Write("</" + reader.Name + ">");
break;
}
}
}