手头项目须要抓取一个用js衬着出来的网站中的数据。运用经常使用的httpclient抓返来的页面是没有数据。上网百度了一下,人人引荐的计划是运用PhantomJS。PhantomJS是一个没有界面的webkit浏览器,能够和浏览器结果一致的运用js衬着页面。Selenium是一个web测试框架。运用Selenium来操纵PhantomJS绝配。然则网上的例子多是Python的。无法,下载了python根据教程搞了一下,卡在了Selenium的导入问题上。遂摒弃,照样用本身习用的c#吧,就不信c#上没有。经由半个小时的折腾,搞定(python折腾了一个小时)。记录下这篇博文,让我等搞c#的新手能用上PhantomJS。
第一步:翻开visual studio 2017 新建一个控制台项目,翻开nuget包管理器。
第二部:搜刮Selenium,装置Selenium.WebDriver。注重:假如要运用代办的话最好装置3.0.0版本。
第三步:写下如下图所示的代码。然则实行的时刻会报错。原因是找不到PhantomJS.exe。这时刻能够去下载一个,也能够继承看第四步。
using OpenQA.Selenium; using OpenQA.Selenium.PhantomJS; using System; namespace ConsoleApp1 { class Program { static void Main(string[] args) { var url = "http://www.baidu.com"; IWebDriver driver = new PhantomJSDriver(GetPhantomJSDriverService()); driver.Navigate().GoToUrl(url); Console.WriteLine(driver.PageSource); Console.Read(); } private static PhantomJSDriverService GetPhantomJSDriverService() { PhantomJSDriverService pds = PhantomJSDriverService.CreateDefaultService(); //设置代办服务器地点 //pds.Proxy = $"{ip}:{port}"; //设置代办服务器认证信息 //pds.ProxyAuthentication = GetProxyAuthorization(); return pds; } } }
第四步:翻开nuget装置Selenium.PhantomJS.WebDriver包。
第五步:运转。能够看到phantomjs.exe被自动下载了。
好了,如许就能够最先你的数据抓取大业了。
以上就是细致引见C#运用Selenium+PhantomJS抓取数据的案例(图文)的细致内容,更多请关注ki4网别的相干文章!