C# Linq到Xml:如果属性值等于IEnumerable中的节点值,则选择元素<;XElement>;
我创建了一个IEnumerable对象,它只包含我希望从xml文件中获取的节点:C# Linq到Xml:如果属性值等于IEnumerable中的节点值,则选择元素<;XElement>;,c#,asp.net,xml,linq,C#,Asp.net,Xml,Linq,我创建了一个IEnumerable对象,它只包含我希望从xml文件中获取的节点: IEnumerable<XElement> rosters = XDocument.Load("roster.xml") .Elements("rosterlist") .Elements("roster")
IEnumerable<XElement> rosters = XDocument.Load("roster.xml")
.Elements("rosterlist")
.Elements("roster")
.Where(w => w.Element("division")
.Value
.Equals("SUPER AWESOME DIVISION"));
但这给了我一个错误:
无法从用法推断方法“System.Linq.Enumerable.Contains(System.Collections.Generic.IEnumerable,TSource)”的类型参数。尝试显式指定类型参数。
我的方法有什么问题?我看到的一个问题是,在最后一个代码片段中,
..Elements(“userid”)
返回一个XElement对象列表,其中不能包含Value属性返回的字符串。这应该有用
IEnumerable<XElement> rosters = obRoot.Elements("rosterlist").Elements("roster");
var rosterUserIds = (rosters.Elements("userid").Select(r => r.Value));
IEnumerable<XElement> users = obRoot.Elements("userlist").Elements("user")
.Where(u => rosterUserIds.Contains(u.Attribute("userid").Value));
IEnumerable<XElement> users = XDocument.Load("user.xml")
.Elements("userlist")
.Elements("user")
.Where(w => rosters.Elements("userid")
.Contains(w.Attribute("userid").Value));
IEnumerable<XElement> rosters = obRoot.Elements("rosterlist").Elements("roster");
var rosterUserIds = (rosters.Elements("userid").Select(r => r.Value));
IEnumerable<XElement> users = obRoot.Elements("userlist").Elements("user")
.Where(u => rosterUserIds.Contains(u.Attribute("userid").Value));
string sXml = @"
<root>
<rosterlist>
<roster>
<userid>1</userid>
<name>R1</name>
<etc></etc>
</roster>
<roster>
<userid>2</userid>
<name>R2</name>
<etc></etc>
</roster>
</rosterlist>
<userlist>
<user userid='1'>
<name>User on roster</name>
</user>
<user userid='5'>
<name>User not on roster</name>
</user>
</userlist>
</root>
";
XElement obRoot = XElement.Parse( sXml );
var results = from user in obRoot.Elements("userlist").Elements("user")
join roster in obRoot.Elements("rosterlist").Elements("roster")
on user.Attribute("userid").Value equals roster.Element("userid").Value
select new {Name=user.Element("name").Value, RosterName=roster.Element("name").Value} ;
foreach (var v in results)
{
Console.WriteLine("{0, -20} on Roster {1, -20}", v.Name, v.RosterName);
}
User on roster on Roster R1