C#使用Selenium+PhantomJS抓取数据

发布时间 - 2026-01-10 23:12:04    点击率:

手头项目需要抓取一个用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#  # 抓取  # 数据  # phantomjs抓取数据  # selenium  # phantomjs  # 用C#+Selenium+ChromeDriver爬取网页(模拟真实的用户浏览行为)  # c# Selenium爬取数据时防止webdriver封爬虫的方法  # c# 从内存中释放Selenium chromedriver.exe  # C# 利用Selenium实现浏览器自动化操作的示例代码  # C#使用Selenium的实现代码  # C#使用selenium实现爬虫  # 是一个  # 代理服务器  # 第四步  # 好了  # 找不到  # 不信  # 半个  # 可以看到  # 所示  # 管理器  # 这篇  # 第二部  # 报错  # 我等  # 要使  # 第三步  # 搞了  # 如下图  # 就可以  # 卡在 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何使用Service Container和依赖注入?(代码示例)  Laravel如何处理CORS跨域请求?(配置示例)  Laravel中Service Container是做什么的_Laravel服务容器与依赖注入核心概念解析  Laravel如何实现API版本控制_Laravel版本化API设计方案  linux写shell需要注意的问题(必看)  如何在景安服务器上快速搭建个人网站?  详解Android中Activity的四大启动模式实验简述  Win11搜索不到蓝牙耳机怎么办 Win11蓝牙驱动更新修复【详解】  Laravel如何使用API Resources格式化JSON响应_Laravel数据资源封装与格式化输出  长沙企业网站制作哪家好,长沙水业集团官方网站?  ,怎么在广州志愿者网站注册?  html5的keygen标签为什么废弃_替代方案说明【解答】  为什么php本地部署后css不生效_静态资源加载失败修复技巧【技巧】  如何在 Pandas 中基于一列条件计算另一列的分组均值  悟空识字如何进行跟读录音_悟空识字开启麦克风权限与录音  网页制作模板网站推荐,网页设计海报之类的素材哪里好?  Laravel事件和监听器如何实现_Laravel Events & Listeners解耦应用的实战教程  Laravel如何生成PDF或Excel文件_Laravel文档导出工具与使用教程  Laravel怎么上传文件_Laravel图片上传及存储配置  悟空识字怎么关闭自动续费_悟空识字取消会员自动扣费步骤  lovemo网页版地址 lovemo官网手机登录  laravel怎么使用数据库工厂(Factory)生成带有关联模型的数据_laravel Factory生成关联数据方法  绝密ChatGPT指令:手把手教你生成HR无法拒绝的求职信  Laravel如何生成URL和重定向?(路由助手函数)  使用豆包 AI 辅助进行简单网页 HTML 结构设计  香港服务器WordPress建站指南:SEO优化与高效部署策略  大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?  Laravel怎么配置不同环境的数据库_Laravel本地测试与生产环境动态切换【方法】  Laravel路由Route怎么设置_Laravel基础路由定义与参数传递规则【详解】  Win11怎么恢复误删照片_Win11数据恢复工具使用【推荐】  php读取心率传感器数据怎么弄_php获取max30100的心率值【指南】  Android仿QQ列表左滑删除操作  米侠浏览器网页背景异常怎么办 米侠显示修复  JavaScript如何实现音频处理_Web Audio API如何工作?  Laravel如何使用软删除(Soft Deletes)功能_Eloquent软删除与数据恢复方法  如何在VPS电脑上快速搭建网站?  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  Laravel怎么在Blade中安全地输出原始HTML内容  小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?  制作企业网站建设方案,怎样建设一个公司网站?  阿里云网站搭建费用解析:服务器价格与建站成本优化指南  实现点击下箭头变上箭头来回切换的两种方法【推荐】  Android 常见的图片加载框架详细介绍  HTML 中动态设置元素 name 属性的正确语法详解  如何在Windows环境下新建FTP站点并设置权限?  如何彻底卸载建站之星软件?  制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?  Laravel如何与Inertia.js和Vue/React构建现代单页应用  香港服务器选型指南:免备案配置与高效建站方案解析  ChatGPT怎么生成Excel公式_ChatGPT公式生成方法【指南】