views:

24

answers:

2

Image I have this XML:

<ipb>
    <profile>
        <id>335389</id>
        <name>stapia.gutierrez</name>
        <rating>0</rating>
    </profile>
</ipb>

I'm trying to get ID, Name and Rating. Any guidance?

Here's what I have and what I receive:

public User FindInformation()
{
  string xml = new WebClient().DownloadString(String.Format("http://www.dreamincode.net/forums/xml.php?showuser={0}", userID));
  XDocument doc = XDocument.Parse(xml);

  var id = from u in doc.Descendants("profile")
                 select (string)u.Element("id");

  var name = from u in doc.Descendants("profile")
                 select (string)u.Element("name");

  var rating = from u in doc.Descendants("profile")
                 select (string)u.Element("rating");

  User user = new User();
  user.ID = id.ToString();
  user.Name = name.ToString();
  user.Rating = rating.ToString();

  return user;
}

This is what I get in my TextBox for testing purposes.

System.Linq.Enumerable+WhereSelectEnumerableIterator`2[System.Xml.Linq.XElement,System.String] System.Linq.Enumerable+WhereSelectEnumerableIterator`2[System.Xml.Linq.XElement,System.String] System.Linq.Enumerable+WhereSelectEnumerableIterator`2[System.Xml.Linq.XElement,System.String]
+1  A: 

You need to extract a single instance of <profile> and then operate on that:

XDocument doc = XDocument.Parse(xml);

foreach(var profile in doc.Descendants("profile"))
{
   var id = profile.Element("id").Value;
   var name = profile.Element("name").Value;
   var rating = profile.Element("rating").Value;

   User user = new User();
   user.ID = id;
   user.Name = name;
   user.Rating = rating;
}

What you're doing now is selecting a list of nodes (doc.Descendants("profile") will return a list of nodes, possibly with just one element - but still a list), and then all the "id" elements from within that list.... not really what you want, I guess!

marc_s
Thanks, this is just what I needed. Haven't worked with XML much. :]
Sergio Tapia
Don't worry I always do. Timer has 8 minutes before I can accept.
Sergio Tapia
@marc_s the system requires a certain amount of time to pass before an aswer can be marked answered. Don't jump the gun.
Mystere Man
Thanks - I do know about the time limit but that seemed to me had pass long ago - guess I'm getting too impatient! Thanks, Sergio.
marc_s
A: 
var id = from u in doc.Descendants("profile")
select (string)u.Element("id");

This & other statements like these will return you an enumerable & not a specific instance. i.e what happens, if your xml has many nodes that satisfy the condition?

So, if you are looking to get the first item (or if you have a xml structure exactly as shown above with no extra nodes), a call to First or FirstOrDefault should help.

shahkalpesh