有人可以帮助我创建 LINQ to XML 查询吗?

发布于 2024-12-21 01:55:22 字数 3937 浏览 0 评论 0原文

我有三个类

ExamProduced:
+ ExamID
+ Date
+ Seed
+ Exercises

Exercise
+ Quantity
+ IsMakeUp
+ Score
+ Answers

Answer
+ IsCorrect

我有这个 Xml 文件

    <Answers ExamID="1" StudentID="abcd" Date="10/26/2011 11:50:34 AM" 
             Seed="495" IsSED="False">
      <Summary>
        <Objective ID="1" MakeUp="False" Quantify="5" 
                   Difficulty="Easy" Accredited="True" Produced="True">
          <Details Result="0" Date="10/26/2011 11:35:18 AM" />
          <Details Result="1" Date="10/26/2011 11:50:34 AM" />
        </Objective>
        <Objective ID="2" MakeUp="True" Quantify="5" 
                   Difficulty="Easy" Accredited="False" Produced="True">
          <Details Result="0" Date="10/26/2011 11:35:18 AM" />
          <Details Result="0" Date="10/26/2011 11:50:34 AM" />
        </Objective>
        <Objective ID="3" MakeUp="True" Quantify="2" 
                   Difficulty="Easy" Accredited="False" Produced="False">
          <Details Result="0" Date="10/26/2011 11:35:18 AM" />
          <Details Result="0" Date="10/26/2011 11:50:34 AM" />
        </Objective>
      </Summary>
      <Answer ProblemID="0" ObjectiveID="1" IsCorrect="True" Difficulty="Easy">
        <Result DataType="System.Decimal" Value="9" />
      </Answer>
      <Answer ProblemID="0" ObjectiveID="1" IsCorrect="True" Difficulty="Easy">
        <Result DataType="System.Decimal" Value="20" />
      </Answer>
      <Answer ProblemID="0" ObjectiveID="1" IsCorrect="True" Difficulty="Easy">
        <Result DataType="System.Decimal" Value="16" />
      </Answer>
      <Answer ProblemID="0" ObjectiveID="1" IsCorrect="True" Difficulty="Easy">
        <Result DataType="System.Decimal" Value="36" />
      </Answer>
      <Answer ProblemID="0" ObjectiveID="1" IsCorrect="True" Difficulty="Easy">
        <Result DataType="System.Decimal" Value="18" />
      </Answer>
      <Answer ProblemID="0" ObjectiveID="2" IsCorrect="False" Difficulty="Easy">
        <Result DataType="System.Decimal" Value="Null" />
      </Answer>
      <Answer ProblemID="0" ObjectiveID="2" IsCorrect="False" Difficulty="Easy">
        <Result DataType="System.Decimal" Value="Null" />
      </Answer>
      <Answer ProblemID="0" ObjectiveID="2" IsCorrect="False" Difficulty="Easy">
        <Result DataType="System.Decimal" Value="Null" />
      </Answer>
      <Answer ProblemID="0" ObjectiveID="2" IsCorrect="False" Difficulty="Easy">
        <Result DataType="System.Decimal" Value="Null" />
      </Answer>
      <Answer ProblemID="0" ObjectiveID="2" IsCorrect="False" Difficulty="Easy">
        <Result DataType="System.Decimal" Value="Null" />
      </Answer>
    </Answers>

那么,我需要一些帮助来创建这个查询。 ExamProduced 属性可以通过 root 获取。然后在练习中,查看标签“Summary”,这里是历史记录。因此,我需要获取“Produced”属性为 true 的那些值。

例如,“producted”为 true 的两个目标是“objectiveId”1 和“2”。然后我需要获取数值数量并进行弥补(用于练习课)。然后就像 1 和 2 目标一样,每个目标都有我需要获得的值是否正确或错误的答案。

提前致谢。

编辑: 例如,在本例中,类应该具有:

ExamProduced
+ ExamID: 1
+ Date: 10/26/2011 11:50:34 AM
+ Seed: 495
+ Exercises: { 2 items }
  {
      Exercise
      {
          + Quantity = 5
          + IsMakeUp = False;
          + Score = 1 (it means one hundred for Answers/Summary/Objective/LastDetail => Result)
          + Answers (5 items)
            {
               Answer
               {
                   + IsCorrect = true
               }
               Answer
               {
                   + Is...
               }
               Ans {..}
               Ans {..}
               Ans {..}
            }
      }
      Exercise
      {
          ...
      }
  }

I've got three classes

ExamProduced:
+ ExamID
+ Date
+ Seed
+ Exercises

Exercise
+ Quantity
+ IsMakeUp
+ Score
+ Answers

Answer
+ IsCorrect

And I've got this Xml file

    <Answers ExamID="1" StudentID="abcd" Date="10/26/2011 11:50:34 AM" 
             Seed="495" IsSED="False">
      <Summary>
        <Objective ID="1" MakeUp="False" Quantify="5" 
                   Difficulty="Easy" Accredited="True" Produced="True">
          <Details Result="0" Date="10/26/2011 11:35:18 AM" />
          <Details Result="1" Date="10/26/2011 11:50:34 AM" />
        </Objective>
        <Objective ID="2" MakeUp="True" Quantify="5" 
                   Difficulty="Easy" Accredited="False" Produced="True">
          <Details Result="0" Date="10/26/2011 11:35:18 AM" />
          <Details Result="0" Date="10/26/2011 11:50:34 AM" />
        </Objective>
        <Objective ID="3" MakeUp="True" Quantify="2" 
                   Difficulty="Easy" Accredited="False" Produced="False">
          <Details Result="0" Date="10/26/2011 11:35:18 AM" />
          <Details Result="0" Date="10/26/2011 11:50:34 AM" />
        </Objective>
      </Summary>
      <Answer ProblemID="0" ObjectiveID="1" IsCorrect="True" Difficulty="Easy">
        <Result DataType="System.Decimal" Value="9" />
      </Answer>
      <Answer ProblemID="0" ObjectiveID="1" IsCorrect="True" Difficulty="Easy">
        <Result DataType="System.Decimal" Value="20" />
      </Answer>
      <Answer ProblemID="0" ObjectiveID="1" IsCorrect="True" Difficulty="Easy">
        <Result DataType="System.Decimal" Value="16" />
      </Answer>
      <Answer ProblemID="0" ObjectiveID="1" IsCorrect="True" Difficulty="Easy">
        <Result DataType="System.Decimal" Value="36" />
      </Answer>
      <Answer ProblemID="0" ObjectiveID="1" IsCorrect="True" Difficulty="Easy">
        <Result DataType="System.Decimal" Value="18" />
      </Answer>
      <Answer ProblemID="0" ObjectiveID="2" IsCorrect="False" Difficulty="Easy">
        <Result DataType="System.Decimal" Value="Null" />
      </Answer>
      <Answer ProblemID="0" ObjectiveID="2" IsCorrect="False" Difficulty="Easy">
        <Result DataType="System.Decimal" Value="Null" />
      </Answer>
      <Answer ProblemID="0" ObjectiveID="2" IsCorrect="False" Difficulty="Easy">
        <Result DataType="System.Decimal" Value="Null" />
      </Answer>
      <Answer ProblemID="0" ObjectiveID="2" IsCorrect="False" Difficulty="Easy">
        <Result DataType="System.Decimal" Value="Null" />
      </Answer>
      <Answer ProblemID="0" ObjectiveID="2" IsCorrect="False" Difficulty="Easy">
        <Result DataType="System.Decimal" Value="Null" />
      </Answer>
    </Answers>

Well, I need a bit of help to create this query. ExamProduced properties can get through the root. Then in exercise, take a look at the tag Summary, in this place is an historial.. so, I need to get those values where the attribute Produced is true.

For example, two objectives where produced is true are the 1 and 2 objectivesId. Then I need to get the values quantity and make up (for exercise class). Then like 1 and 2 objective were produced, each one has answers I need to get if the value was correct o wrong.

Thanks in advance.

EDIT:
For example at this case, the classes should have:

ExamProduced
+ ExamID: 1
+ Date: 10/26/2011 11:50:34 AM
+ Seed: 495
+ Exercises: { 2 items }
  {
      Exercise
      {
          + Quantity = 5
          + IsMakeUp = False;
          + Score = 1 (it means one hundred for Answers/Summary/Objective/LastDetail => Result)
          + Answers (5 items)
            {
               Answer
               {
                   + IsCorrect = true
               }
               Answer
               {
                   + Is...
               }
               Ans {..}
               Ans {..}
               Ans {..}
            }
      }
      Exercise
      {
          ...
      }
  }

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

扬花落满肩 2024-12-28 01:55:22

这是我为您尝试构建的数据设计的稍微过度设计的解决方案。使用它:

XElement xml = XElement.Load(...);
var exam = ExamProduced.ParseElement(xml);

以及实际实现:

public class ExamProduced
{
    public int ExamID { get; set; }
    public DateTime Date { get; set; }
    public int Seed { get; set; }
    public ExerciseCollection Exercises { get; private set; }

    public static ExamProduced ParseElement(XElement answersElement)
    {
        if (answersElement == null) throw new ArgumentNullException("answersElement");
        if (answersElement.Name != "Answers") throw new ArgumentException("element must be an <Answers> element");

        return new ExamProduced
        {
            ExamID = (int)answersElement.Attribute("ExamID"),
            Date = (DateTime)answersElement.Attribute("Date"),
            Seed = (int)answersElement.Attribute("Seed"),
            Exercises = ExerciseCollection.ParseElement(answersElement),
        };
    }
}

public class ExerciseCollection : ReadOnlyCollection<Exercise>
{
    private ExerciseCollection(IEnumerable<Exercise> exercises) : base(exercises.ToList()) { }

    internal static ExerciseCollection ParseElement(XElement answersElement)
    {
        var exercises =
            from objective in answersElement.XPathSelectElements("Summary/Objective")
            join answer in answersElement.Elements("Answer")
                on (int)objective.Attribute("ID") equals (int)answer.Attribute("ObjectiveID")
                into answers
            where answers.Any()
            select Exercise.ParseElements(objective, answers);

        return new ExerciseCollection(exercises);
    }
}

public class Exercise
{
    public int Quantity
    {
        get { return Answers != null ? Answers.Count : 0; }
    }
    public Decimal Score { get; set; }
    public bool IsMakeUp { get; set; }
    public AnswerCollection Answers { get; private set; }

    internal static Exercise ParseElements(XElement objective, IEnumerable<XElement> answerElements)
    {
        return new Exercise
        {
            IsMakeUp = (bool)objective.Attribute("MakeUp"),
            Score = objective.Elements("Details").Select(e => (decimal)e.Attribute("Result")).Last(),
            Answers = AnswerCollection.ParseElements(answerElements),
        };
    }
}

public class AnswerCollection : ReadOnlyCollection<Answer>
{
    private AnswerCollection(IEnumerable<Answer> answers) : base(answers.ToList()) { }

    internal static AnswerCollection ParseElements(IEnumerable<XElement> answerElements)
    {
        var answers =
            from answerElement in answerElements
            select Answer.ParseElement(answerElement);

        return new AnswerCollection(answers);
    }
}

public class Answer
{
    public bool IsCorrect { get; set; }

    internal static Answer ParseElement(XElement answerElement)
    {
        return new Answer
        {
            IsCorrect = (bool)answerElement.Attribute("IsCorrect"),
        };
    }
}

Here's my slightly over-engineered solution for the data you're trying to build. To use it:

XElement xml = XElement.Load(...);
var exam = ExamProduced.ParseElement(xml);

And the actual implementation:

public class ExamProduced
{
    public int ExamID { get; set; }
    public DateTime Date { get; set; }
    public int Seed { get; set; }
    public ExerciseCollection Exercises { get; private set; }

    public static ExamProduced ParseElement(XElement answersElement)
    {
        if (answersElement == null) throw new ArgumentNullException("answersElement");
        if (answersElement.Name != "Answers") throw new ArgumentException("element must be an <Answers> element");

        return new ExamProduced
        {
            ExamID = (int)answersElement.Attribute("ExamID"),
            Date = (DateTime)answersElement.Attribute("Date"),
            Seed = (int)answersElement.Attribute("Seed"),
            Exercises = ExerciseCollection.ParseElement(answersElement),
        };
    }
}

public class ExerciseCollection : ReadOnlyCollection<Exercise>
{
    private ExerciseCollection(IEnumerable<Exercise> exercises) : base(exercises.ToList()) { }

    internal static ExerciseCollection ParseElement(XElement answersElement)
    {
        var exercises =
            from objective in answersElement.XPathSelectElements("Summary/Objective")
            join answer in answersElement.Elements("Answer")
                on (int)objective.Attribute("ID") equals (int)answer.Attribute("ObjectiveID")
                into answers
            where answers.Any()
            select Exercise.ParseElements(objective, answers);

        return new ExerciseCollection(exercises);
    }
}

public class Exercise
{
    public int Quantity
    {
        get { return Answers != null ? Answers.Count : 0; }
    }
    public Decimal Score { get; set; }
    public bool IsMakeUp { get; set; }
    public AnswerCollection Answers { get; private set; }

    internal static Exercise ParseElements(XElement objective, IEnumerable<XElement> answerElements)
    {
        return new Exercise
        {
            IsMakeUp = (bool)objective.Attribute("MakeUp"),
            Score = objective.Elements("Details").Select(e => (decimal)e.Attribute("Result")).Last(),
            Answers = AnswerCollection.ParseElements(answerElements),
        };
    }
}

public class AnswerCollection : ReadOnlyCollection<Answer>
{
    private AnswerCollection(IEnumerable<Answer> answers) : base(answers.ToList()) { }

    internal static AnswerCollection ParseElements(IEnumerable<XElement> answerElements)
    {
        var answers =
            from answerElement in answerElements
            select Answer.ParseElement(answerElement);

        return new AnswerCollection(answers);
    }
}

public class Answer
{
    public bool IsCorrect { get; set; }

    internal static Answer ParseElement(XElement answerElement)
    {
        return new Answer
        {
            IsCorrect = (bool)answerElement.Attribute("IsCorrect"),
        };
    }
}
逆流 2024-12-28 01:55:22

如果我正确理解你的要求,类似这样的事情应该可以解决问题:

public static ExamProduced GetExamProduced(XElement xml) {
    var examProduced = new ExamProduced
    {
        ExamID = (int)xml.Attribute("ExamID"),
        Date = (DateTime)xml.Attribute("Date"),
        Seed = (int)xml.Attribute("Seed"),
        Exercises = GetExercises(xml)
    };

    return examProduced;
}

public static List<Exercise> GetExercises(XElement xml) {
    var objs = 
        from objective in xml.Descendants("Objective")
        where (bool)objective.Attribute("Produced")
        let id = (int)objective.Attribute("ID")
        select new Exercise
            {
                ExerciseID = id,
                IsMakeUp = (bool)objective.Attribute("MakeUp"),
                Quantity = (int)objective.Attribute("Quantify"),
                Score = (int)objective.Elements().Last().Attribute("Result"),
                Answers = GetAnswers(xml, id)
            };

        return objs.ToList();
}

public static List<Answer> GetAnswers(XElement xml, int objectiveId) {
    var answers = 
            from answer in xml.Descendants("Answer")
            where (int)answer.Attribute("ObjectiveID") == objectiveId
            select new Answer
              {
                IsCorrect = (bool)answer.Attribute("IsCorrect")
              };
    return answers.ToList();
}

If I understood your requirements correctly, something like this should do the trick:

public static ExamProduced GetExamProduced(XElement xml) {
    var examProduced = new ExamProduced
    {
        ExamID = (int)xml.Attribute("ExamID"),
        Date = (DateTime)xml.Attribute("Date"),
        Seed = (int)xml.Attribute("Seed"),
        Exercises = GetExercises(xml)
    };

    return examProduced;
}

public static List<Exercise> GetExercises(XElement xml) {
    var objs = 
        from objective in xml.Descendants("Objective")
        where (bool)objective.Attribute("Produced")
        let id = (int)objective.Attribute("ID")
        select new Exercise
            {
                ExerciseID = id,
                IsMakeUp = (bool)objective.Attribute("MakeUp"),
                Quantity = (int)objective.Attribute("Quantify"),
                Score = (int)objective.Elements().Last().Attribute("Result"),
                Answers = GetAnswers(xml, id)
            };

        return objs.ToList();
}

public static List<Answer> GetAnswers(XElement xml, int objectiveId) {
    var answers = 
            from answer in xml.Descendants("Answer")
            where (int)answer.Attribute("ObjectiveID") == objectiveId
            select new Answer
              {
                IsCorrect = (bool)answer.Attribute("IsCorrect")
              };
    return answers.ToList();
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文