猿问

使用 HtmlAgilityPack 显示节点内容时遇到问题

我在此网址上抓取数据时遇到问题:http://patorjk.com/software/taag/#p=display&f=Graffiti&t =类型%20Something%20

问题是:我编写了一段代码,该代码应该抓取某个节点的内容并将其显示在控制台上。然而,节点中的内容和特定节点本身似乎无法访问,但我知道它们存在,因为我在代码中创建了一个条件,以便让我知道具有特定主体的节点是否是被发现并且确实被发现但由于某种原因没有显示:

private static void getTextArt(string font, string word)

        {

            HtmlWeb web = new HtmlWeb();

            //cureHtml method is just meant to return the http address

            HtmlDocument htmlDoc = web.Load(cureHtml(font, word));

            if(web.Load(cureHtml(font, word)) != null)

                Console.WriteLine("Connection Established");

            else

                Console.WriteLine("Connection Failed!");


            var nodes = htmlDoc.DocumentNode.SelectSingleNode(nodeXpath).ChildNodes;


            foreach(HtmlNode node in nodes)

            {

                if(node != null)

                    Console.WriteLine("Node Found.");

                else

                    Console.WriteLine("Node not found!");


                Console.WriteLine(node.OuterHtml);

            }

        }


        private const string nodeXpath = "//div[@id='maincontent']";

}

网站显示的Html如下所示:

网站内的 Html 代码。箭头指向我试图到达的节点以及我试图在控制台上显示的内容

当我在控制台上运行代码来检查节点及其内容并尝试显示 Xpath 的 OuterHtml 字符串时,控制台将如下显示它:

控制台窗口显示

我希望你们中的一些人能够向我解释为什么会出现这种情况。我已经在谷歌上尝试了两天的各种搜索,试图找出问题所在,但没有用。谢谢大家。


慕田峪7331174
浏览 110回答 1
1回答

斯蒂芬大帝

您想要的内容是动态加载的。请改用HtmlWeb.LoadFromBrowser() 方法。另外,检查 htmlDoc 是否有 null,而不是调用两次。您当前的逻辑并不能保证您的状态。        HtmlDocument htmlDoc = web.LoadFromBrowser(cureHtml(font, word));        if (htmlDoc != null)            Console.WriteLine("Connection Established");        else            Console.WriteLine("Connection Failed!");此外,您还需要对结果进行解码。            Console.WriteLine(WebUtility.HtmlDecode(node.OuterHtml));如果这不起作用,则说明您的cureHtml()方法已损坏,或者您的目标是 .NET Core :)
随时随地看视频慕课网APP

相关分类

Html5
我要回答