所以我有一个看起来像这样的XML文件。
<recept id="1" sort="vardag">
<!-- namn och portioner förekommer endast en gång i varje respektive element-->
<namn>Pannkaka</namn>
<portioner>4 portioner</portioner>
<!--elementet ingrediens inehåller PCDATA och ett underelement dvs mangd
och kan förekomma minst 1 eller flera gånger-->
<ingrediens>
Ägg<mangd> 3 st</mangd>
</ingrediens>
<ingrediens>
Mjölk<mangd> 10 dl</mangd>
</ingrediens>
<ingrediens>
Mjöl<mangd> 3 dl</mangd>
</ingrediens>
<ingrediens>
Salt<mangd> En nypa</mangd>
</ingrediens>
<ingrediens>
Matfett<mangd> 2 msk matolja eller smör</mangd>
</ingrediens>
<!--elementet tillredning kan endast förekomma en gång i elementet recept och
innehåller PCDATA-->
<tillredning>
<steg>Ta fram en lagom stor bunke</steg>
<steg>Smält smöret i en kastrull</steg>
<steg>Vispa ihop ägg, mjölk, mjöl och saltet</steg>
<steg>Låt smöret svalna en smula och blanda sen det i smeten</steg>
<steg>Stek gyllenbruna i stekpanna på medelvärme</steg>
</tillredning>
</recept>
现在,当我搜索ID时,我想要加载之间的所有内容。 我现在只是用+添加它们但是如果一个子类别有多个它只加载其中一个。
private void buttonSök_Click(object sender, EventArgs e)
{
var v = (from x in el.Descendants("recept")
where x.Attribute("id").Value.ToLower() == textBoxID.Text.ToLower()
select x).FirstOrDefault();
if (v == null)
{
MessageBox.Show("Finns inte!");
}
richTextBox1.Text = v.Element("namn").Value + "\r\n" + v.Element("portioner").Value + "\r\n" + v.Element("ingredienser").Value +"\r\n" + v.Element("tillredning").Value;
}
答案 0 :(得分:0)
考虑使用类似下面的方法来提取成分:
private static string ExtractIngredients(XElement v)
{
var ingredients = v
.Elements("ingrediens")
.Select(e =>
e.DescendantNodes().OfType<XText>().First().Value +
": " +
e.Element("mangd").Value);
return String.Join("\r\n", ingredients);
}
在这里,您使用成分名称是XML文本节点的事实,并将它们称为“ingrediens”节点的单独子项。