Linq - 无法将类型'System.Collections.Generic.IEnumerable <system.xml.linq.xelement>'隐式转换为'System.Collections.Generic.List <string>'</string> </system.xml.linq.xelement >

时间:2011-12-29 05:50:17

标签: c# linq

我收到以下错误:

  

无法将类型'System.Collections.Generic.IEnumerable'隐式转换为'System.Collections.Generic.List'。存在显式转换(您是否错过了演员?)

我的代码如下:

 public Profile PullActiveProfile()
  {
   //currentProfile.Decks = new List<string>();
    return currentProfile = (from profiles in xmlDoc.Element("PlayerPofiles").Elements("Player")where (string)profiles.Element("Active") == "True"
    select new Profile
      {
       Name = (string)profiles.Element("Name"),
       Type = (string)profiles.Element("Type"),
       Verified = (string)profiles.Element("Verified"),
       Password = (string)profiles.Element("Password"),
       Email = (string)profiles.Element("Email"),
       Sex = (string)profiles.Element("Sex"),
       Avatar = (string)profiles.Element("Avatar").Attribute("path") ?? "",
       Created = (DateTime)profiles.Element("Created"),
       Birthday = (string)profiles.Element("Birthday") ?? "",
       Wins = (string)profiles.Element("Ratio").Element("Win") ?? "0",
       Losses = (string)profiles.Element("Ratio").Element("Loss") ?? "0",
       Abandoned = (string)profiles.Element("Ratio").Element("Abandoned"),
       // The following line is where I get the error. The decks node can have many descendants
       Decks = profiles.Elements("Decks").Descendants() 
         .Select(x => x.ToString()).ToList();
       }).FirstOrDefault(); 
    }

这是节点结构:

<PlayerPofiles>
<Player>
  <Name>Stacey - Online</Name>
  <Type>Full/Basic</Type>
  <Active>True</Active>
  <Verified>True</Verified>
  <Password>pass</Password>
  <Email>xxxx@gmail.com</Email>
  <Sex>Female</Sex>
  <Avatar path="/images/Treasure/BroadSword.png" />
  <Ratio>
    <Win>0</Win>
    <Loss>0</Loss>
    <Abandoned>0</Abandoned>
  </Ratio>
  <Created>6/19/2011</Created>
  <Birthday>09/28/1989</Birthday>
  <Decks>
    <Base />
    <Booty />
  </Decks>
</Player>

3 个答案:

答案 0 :(得分:7)

我认为你应该检索一个List&lt; string&gt;,因为只检索后代会给你一个[IEnumerable for XElement]。 (http://msdn.microsoft.com/en-us/library/bb337483.aspx)但你需要的是一个IEnumerable类型string。将'requiredname'替换为填写List中所需的内容:

profiles.Elements("Decks").Descendants()
              .Select(x => x.requiredname).ToList()

答案 1 :(得分:2)

删除“;”在ToList()

之后
var profiles = xmlDoc.Element("PlayerPofiles").Elements("Player")
                     .where(profile =>(profile.Element("Active") == "True"))
                     .FirstOrDefault();

if(profiles!=null){
return new Profile
      {
       Name = (string)profiles.Element("Name"),
       Type = (string)profiles.Element("Type"),
       Verified = (string)profiles.Element("Verified"),
       Password = (string)profiles.Element("Password"),
       Email = (string)profiles.Element("Email"),
       Sex = (string)profiles.Element("Sex"),
       Avatar = (string)profiles.Element("Avatar").Attribute("path") ?? "",
       Created = (DateTime)profiles.Element("Created"),
       Birthday = (string)profiles.Element("Birthday") ?? "",
       Wins = (string)profiles.Element("Ratio").Element("Win") ?? "0",
       Losses = (string)profiles.Element("Ratio").Element("Loss") ?? "0",
       Abandoned = (string)profiles.Element("Ratio").Element("Abandoned"),
       // The following line removed the ;
       Decks = profiles.Elements("Decks").Descendants() 
         .Select(x => x.Value.ToString()).ToList()
       }); 
}
else
{
//Handle if null
}

答案 2 :(得分:0)

我建议您先从xml中获取记录,然后执行以下映射: -

var currentProfile = from profiles in xmlDoc.Element("PlayerPofiles").Elements("Player")
                     where (string)profiles.Element("Active") == "True".FirstOrDefault()
                     select profile
Profile profile = new Profile();
profile.Name = currentProfile.Name;
. // all your properties mapping
.
.
return profile;