我有以下xml模式。
<Rooms>
<Room RoomNumber="room1" EMAIL="ssds@dsfd.com" dsfdd=""/>
<Room RoomNumber="room2" EMAIL="ssds@sdd.com" dsfdd=""/>
</Rooms>我必须返回基于输入的电子邮件地址(程序的输入是房间号)。
如何使用LINQ to XML实现这一点?
发布于 2013-03-07 17:51:54
var doc = XDocument.Load(myXmlFilePath);
// or doc = XDocument.Parse(myXmlString);
string roomNumber = "room1";
var emailQuery = from room in doc.Root.Elements("Room")
where (string)room.Attribute("RoomNumber") == roomNumber
select (string)room.Attribute("EMAIL");然后,通过这样的查询,您可以获得结果:
// if there is always only one <Room> with given roomNumber
var email = emailQuery.First();
// otherwise
var emails = emailQuery.ToList();发布于 2013-03-07 17:39:25
试试这个:
var xml = XElement.Parse("<Rooms>"+
"<Room RoomNumber=\"room1\" EMAIL=\"ssds@dsfd.com\" dsfdd=\"\"/>"+
"<Room RoomNumber=\"room2\" EMAIL=\"ssds@sdd.com\" dsfdd=\"\"/>"+
"</Rooms>");
string room = "room1"; //input
var email = xml.Elements("Room")
.Where(c => c.Attribute("RoomNumber").Value == room)
.Select(c => c.Attribute("EMAIL").Value).FirstOrDefault();https://stackoverflow.com/questions/15267530
复制相似问题