2

こんにちは、私はこの xml を持っています。Plan のリストと PlanTerms のリストを取得したいと考えています。

   Plan
    {
    name = "Premium"
    List<Terms>{
      24 months/24000 miles
     36 months/36000 miles
    }

    }

XML:

<plan>
    <planid>1</planid>
    <plantitle>Premium</plantitle>
    <plandesc>12 months / 12,000 miles</plandesc>
    <planwarranty>NA</planwarranty>
    <plancoveredterm>12</plancoveredterm>

</plan>
<plan>
    <planid>2</planid>
    <plantitle>Premium</plantitle>
    <plandesc>24 months / 24,000 miles</plandesc>
    <planwarranty>NA</planwarranty>
    <plancoveredterm>24</plancoveredterm>

</plan>
<plan>
    <planid>3</planid>
    <plantitle>Premium</plantitle>
    <plandesc>36 months / 36,000 miles</plandesc>
    <planwarranty>NA</planwarranty>
    <plancoveredterm>36</plancoveredterm>

</plan>

次のコードブロックを使用しています

XDocument xdoc = XDocument.Parse(providerResponse);
XElement root = xdoc.Root;

var quotePlan = (from planInfo in root.Descendants("plan")
                 select new QuotePlanMbp
                 {
                     Name = planInfo.Element("plantitle").Value.ToString(),
                     QuoteTerms = (from planTerm in root.Descendants("plan")
                                   select new QuoteTermMbp
                                   {
                                       TermMonths = planTerm.Element("plancoveredterm").Value != null ? Convert.ToInt32(planTerm.Element("plancoveredterm").Value) : 0,
                                       TermMiles = planTerm.Element("plancoveredmiles").Value != null ? Convert.ToInt32(planTerm.Element("plancoveredmiles").Value) : 0,
                                       TermCost = planTerm.Element("plancost").Value != null ? Convert.ToDecimal(planTerm.Element("plancost").Value) : 0
                                   }).ToList<QuoteTerm>()
                  }).GroupBy(plan => plan.Name);

これにより、最上位のプラン レコードが 3 つ得られますが、必要なプラン レコードは 1 つだけです (名前は常に「プレミアム」であるため)。この問題を解決するための微調整を提案してください。

4

1 に答える 1

2

用語を選択する前に、プランを名前でグループ化する必要があります。次に、プラン グループごとに条件のリストを選択します。

from planInfo in root.Descendants("plan")
group planInfo by (string)planInfo.Element("plantitle") into g
select new QuotePlanMbp {
   Name = g.Key,
   QuoteTerms = 
      (from planTerm in g
       let months = (int?)planTerm.Element("plancoveredterm")
       select new QuoteTermMbp {
           TermMonths = months.GetValueOrDefault(),
           TermMiles = (int)((int?)planTerm.Element("plancoveredmiles") ?? 0),
           TermCost = ((int?)planTerm.Element("plancost")).GetValueOrDefault()
       }).ToList<QuoteTermMbp>()
};

ここでは、項の整数プロパティを解析するための 3 つの異なる手法も示しました。好きな方を選択してください。

于 2013-09-10T19:52:20.393 に答える