我有这个xml。
<?xml version="1.0" encoding="utf-8"?>
<feed xml:lang="el-gr" xmlns="http://www.w3.org/2005/Atom">
<title type="text">name.gr</title>
<updated>2011-07-23</updated>
<link href="link" />
<entry>
<title type="html">Οι επιθέσεις σε σκανδιναβικές χώρες</title>
<summary type="text">Η Νορβηγία, μία από τις σκανδιναβικές χώρες, έζησε μετά από πάρα πολλά χρόνια (2006) τον τρόμο. Δείτε αναλυτικά τις τελευταίες «τυφλές» επιθέσεις τα τελευταία χρόνια:...</summary>
<published>2011-07-23T12:54:00+03:00</published>
<link href="link" />
</entry>
我想解析里面的一些元素。为此,我使用以下LINQ代码。
var list = from y in xelement.Descendants("entry")
select new Update()
{
Title = y.Element("title").Value,
Pubdate = y.Element("published").Value,
Descr = y.Element("content").Value,
Link = y.Element("link").Attribute("href").Value
};
但它不起作用。谁能告诉我我做错了什么?
答案 0 :(得分:1)
节点都在http://www.w3.org/2005/Atom
命名空间中。因此,您需要使用此命名空间为查询添加前缀,否则查询会尝试在空命名空间中查找这些元素。
XNamespace atom = "http://www.w3.org/2005/Atom";
var list = from y in xelement.Descendants(atom+"entry")
select new Update()
{
Title = y.Element(atom+"title").Value,
Pubdate = y.Element(atom+"published").Value,
Descr = y.Element(atom+"content").Value,
Link = y.Element(atom+"link").Attribute("href").Value
};
答案 1 :(得分:0)
在您的XML示例中,缺少“feed”结束标签,并且您使用的是“内容”元素,但我猜“摘要”是正确的。