Html Agility Pack selectnodes返回null

c# html-agility-pack html-parsing

我正在使用Windows Phone 8设备并尝试使用来自http://www.livescience.com/41480-3d-printed-kidneys-take-small-steps.html的 html敏捷包来解析html文档我可以获得<title>标签很容易,但现在我想从该文档中获取整个<p>标签。我已经尝试了这两个解决方案但它不起作用。这是我基于这些解决方案的实际代码

private void loadDoc()
    {
        try
        {
            HtmlWeb.LoadAsync("http://www.livescience.com/41480-3d-printed-kidneys-take-small-steps.html", Html_Completed);
        }
        catch (Exception ex)
        {
            MessageBox.Show(ex.ToString());
        }
    }

    private void Html_Completed(object sender, HtmlDocumentLoadCompleted e)
    {
        doc = e.Document;
        title = doc.DocumentNode.SelectSingleNode("//title");
        p = doc.DocumentNode.SelectNodes("//p");
        foreach(var node in p)
        {
          pr = node.InnerText; //that's the text you are looking for
        }
        text1.Text = title.InnerText;
        if (!pr.Equals("") && pr != "")
        {
            text2.Text = pr;
        }
        else
        {
            MessageBox.Show("null");
        }
    }

我使用if块来确定foreach是否返回null。有人知道如何解决这个问题吗?我将不胜感激任何帮助。谢谢。

热门答案

尝试做:

p = doc.DocumentNode.SelectNodes(".//p");

代替:

p = doc.DocumentNode.SelectNodes("//p");

因为p是一种标签,而不是类或id。



许可下: CC-BY-SA with attribution
不隶属于 Stack Overflow
这个KB合法吗? 是的,了解原因
许可下: CC-BY-SA with attribution
不隶属于 Stack Overflow
这个KB合法吗? 是的,了解原因