爬虫selenium解决网页空白问题

from selenium.webdriver import Chrome
import time
# https://blog.csdn.net/zhoukeguai/article/details/113247342
# driver = Chrome("./chromedriver.exe")
# 把当前目录下的chromdriver.exe复制到你的python安装目录. 我用的124版本, 根据自己需要下载即可.
from selenium import webdriver
from selenium.webdriver.chrome.options import Options  # 导入无头浏览器的包

opt = Options()
opt.add_argument('--headless')  # 设置为无头
# opt.add_argument('--disable-gpu')  # 设置没有使用gpu
opt.add_argument('user-agent=Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/86.0.4240.198 Safari/537.36')


user_agent = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.3"
opt.add_argument(f'user-agent={user_agent}')

opt.add_experimental_option("excludeSwitches",["enable-automation"])
opt.add_experimental_option("useAutomationExtension",'False')






opt.add_argument('--disable-javascript')
opt.add_argument('disable-infobars')
opt.add_experimental_option('detach', True)
opt.add_argument('-disable-blink-features=AutomationControlled')





# =====这个可以解决网页空白的问题.
web = Chrome(options= opt)  # 然后配置放到浏览器上
web.execute_cdp_cmd("Page.addScriptToEvaluateOnNewDocument", {
                "source": """
                Object.defineProperty(navigator, 'webdriver', {
                  get: () => undefined
                })
              """
            })

# http://www.chinadrugtrials.org.cn/clinicaltrials.searchlistdetail.dhtml
web.get('http://www.chinadrugtrials.org.cn/clinicaltrials.searchlistdetail.dhtml')
  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Selenium打开网页时,有几个可能的原因导致页面显示为空白。 第一个可能的原因是Selenium没有等待页面完全加载就开始获取页面内容。在某些情况下,网页的内容需要一些时间才能完全加载和渲染。为了解决这个问题,可以使用Selenium的等待功能,通过等待页面元素的出现或等待页面的特定状态来确保页面加载完成后再获取内容。 第二个可能的原因是Selenium的浏览器驱动程序版本与使用的浏览器版本不兼容。不同的浏览器驱动程序适用于特定版本的浏览器。如果驱动程序版本与浏览器版本不匹配,可能会导致页面显示为空白解决这个问题的方法是确保Selenium的浏览器驱动程序版本与使用的浏览器版本一致。 第三个可能的原因是网页使用了动态内容,而Selenium获取的是页面加载时的静态内容。有些网页使用JavaScript等技术来动态地更新页面内容,这些动态内容可能在页面加载后才会生成。如果Selenium只获取页面加载时的静态内容,可能会导致页面显示为空白解决这个问题的方法是使用Selenium的等待功能,等待页面的动态内容生成后再获取页面内容。 综上所述,Selenium打开网页空白的原因可能是没有等待页面完全加载、浏览器驱动程序版本与浏览器版本不兼容或者网页使用了动态内容。解决这个问题的方法是使用Selenium的等待功能、确保浏览器驱动程序版本与浏览器版本一致,以及等待页面的动态内容生成后再获取页面内容。 (Selenium是一个用于自动化测试的工具,常用于模拟用户在网页上的操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

15122306087

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值