3

我在解析多个 XML 字段时遇到问题

这是 XML 的风格:

<students>
  <student>
    <student_id>1</student_id>
    <student_name>Mike</student_name>
    <subjects>
      <subject>
        <school_subject>History</school_subject>
      </subject>
      <subject>
        <school_subject>Maths</school_subject>
      </subject>
      <subject>
        <school_subject>English</school_subject>
      </subject>
    </subjects>
  </student>
  <student>
    ...
  </student>
</students>

我可以将它解析为像 student_id 和 student_name 这样的简单字段,但是当同一个字段有多个重复时,我不知道该怎么做:/ 这是我的解析源代码。

我做了两节课:

  • 包含学校科目名称的科目
  • 包含 id 和 name 以及班级主题列表的学生。

现在源代码:

List<Student> L1 = new List<Student>();

XDocument doc = XDocument.Load(s);
var q = from b in doc.Descendants("student")
select new
{
    s_id = (string)b.Element("student_id"),
    s_name = (string)b.Element("student_name"),
    s_subject = (Subject)b.Elements("school_subject")
};
foreach (var p in q)
{
    L1.Add(new Student() { id = p.s_id, name = p.s_name, subject = p.s_subject });
}
listBox1.ItemsSource = L1;

感谢您的阅读,并为我糟糕的英语感到抱歉。

4

2 回答 2

5

根据您的 xml 学生可以有几个科目。因此,您需要收集科目作为学生的财产:

public class Student
{
    public int Id { get; set; }
    public string Name { get; set; }
    public List<Subject> Subjects { get; set; }
}

public class Subject
{
    public string Name { get; set; }
}

这里是解析。要填写获取学生的科目,您需要进行子查询:

XDocument xdoc = XDocument.Load(s);
IEnumerable<Student> students =
    from s in xdoc.Descendants("student")
    select new Student()
    {
        Id = (int)s.Element("student_id"), // you can cast to int
        Name = (string)s.Element("student_name"),
        Subjects = s.Element("subjects") // here goes sub query
                    .Elements("subject")
                    .Select(subj => new Subject() { 
                       Name = (string)subj.Element("school_subject") 
                    }).ToList()
    };

顺便说一句,我认为您可以使用简单的字符串来保存主题名称-您实际上并不需要为此上课。

于 2012-12-16T19:14:29.670 回答
0

因为您在 xml 中有多个主题s_subject应该listSubject

doc.Elements("Student").Select(
x=>
    s_id = (string)x.Element("student_id"),
    s_name = (string)x.Element("student_name"),
    s_subject = x.Element("subjects").Elements("subject")
                 .Select(s=>s.Element("school_subject").Value)
                 .ToList<Subject>()
);
于 2012-12-16T18:54:53.383 回答