Wählen Sie einzigartige XElements (durch Attribut) mit einem Filter mit LinqToXml
-
19-08-2019 - |
Frage
Ich habe ein XML-Dokument suchen ähnlich wie folgt aus:
<items>
<item cat="1" owner="14">bla</item>
<item cat="1" owner="9">bla</item>
<item cat="1" owner="14">bla</item>
<item cat="2" owner="12">bla</item>
<item cat="2" owner="12">bla</item>
</items>
Nun möchte Ich mag alle einzigartigen Besitzer zu bekommen (Ich brauche eigentlich nur den Attributwert des Eigentümers) zu einer bestimmten Kategorie gehören eine Linq-Abfrage verwenden. In meinem Beispiel zurückkehren würde die Abfrage für cat 1 eine Liste mit 9 und 14. Wie kann ich das tun? Linq-Syntax würde über Lambdas bevorzugt werden. Vielen Dank im Voraus;)
Lösung
das Fragment der Annahme ist in itemsElement:
var distinctOwners = (from item in itemsElement.Element("item")
where itemElements.Attribute("cat") == 1
select item.Attribute("owner")).Distinct();
Wir entschuldigen uns für die Formatierung und Vertiefung!
Andere Tipps
Versuchen Sie, diese Funktion: -
static IEnumerable<int> GetOwners(XDocument doc, string cat)
{
return from item in doc.Descendants("item")
where item.Attribute("cat").Value == cat
select (int)item.Attribute("owner")).Distinct();
}
XElement ele = XElement.Parse(@"<items><item cat=""1"" owner=""14"">bla</item><item cat=""1"" owner=""9"">bla</item>" +
@"<item cat=""1"" owner=""14"">bla</item><item cat=""2"" owner=""12"">bla</item>" +
@"<item cat=""2"" owner=""12"">bla</item></items>");
int cat = 1;
List<int> owners = ele.Elements("item")
.Where(x=>x.Attribute("cat").Value==cat.ToString()).Select(x=>Convert.ToInt32(x.Attribute("owner").Value)).Distinct().ToList();
Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow