この URL から Google カレンダーのイベントを解析しようとしています: http://www.google.com/calendar/feeds/amchamlva%40gmail.com/public/full で、ここに私のコードがあります:
static IEnumerable<Event> getEntryQuery(XDocument xdoc)
{
return from entry in xdoc.Root.Elements().Where(i => i.Name.LocalName == "entry")
select new Event
{
EventId = entry.Elements().First(i => i.Name.LocalName == "id").Value,
Published = DateTime.Parse(entry.Elements().First(i => i.Name.LocalName == "published").Value),
Title = entry.Elements().First(i => i.Name.LocalName == "title").Value,
Content = entry.Elements().First(i => i.Name.LocalName == "content").Value,
Where = entry.Elements().First(i => i.Name.LocalName == "gd:where").FirstAttribute.Value,
Link = entry.Elements().First(i => i.Name.LocalName == "link").Attribute("href").Value,
};
}
using (StreamReader httpwebStreamReader = new StreamReader(e.Result))
{
var results = httpwebStreamReader.ReadToEnd();
XDocument doc = XDocument.Parse(results);
System.Diagnostics.Debug.WriteLine(doc);
var myFeed = getEntryQuery(doc);
foreach (var feed in myFeed)
{
System.Diagnostics.Debug.WriteLine(feed.Content);
}
}
そして、これを除いて、ほとんど問題なく動作します:
Where = entry.Elements().First(i => i.Name.LocalName == "gd:where").FirstAttribute.Value,
おそらく値がnullであるため、例外が発生しました。実際には、valueString属性値を取得する必要があります(この場合は「どこか」など)
<gd:where valueString='Somewhere'/>