具体介绍C#使用Selenium+PhantomJS抓取数据的案例(图文)


本文摘自PHP中文网,作者黄舟,侵删。

本文主要介绍了C#使用Selenium+PhantomJS抓取数据的方法步骤,具有很好的参考价值,下面跟着小编一起来看下吧

手头项目需要抓取一个用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。这时候可以去下载一个,也可以继续看第四步。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

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抓取数据的案例(图文)的详细内容!

相关阅读 >>

C#正则表达式元字符详解

实现C#listview点击列头排序的示例代码分享

原来斐波拉契数列还有这种写法,你知道吗?

几个优秀的java和C#代码转换工具

详细介绍使用msscriptcontrol在C#中读取json数据的方法

浅谈C#方法的六种参数

C#与vb.net混合开发测试的详细介绍(图文)

C# system.drawing.region类的方法使用(图解)

详细介绍C# string格式的日期时间字符串转为datetime类型的方法

详解winform C#中子窗体关闭刷新父窗体的示例代码

更多相关阅读请进入《C#》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...