记录一次爬虫实战中使用selenium遇到的问题

目标站点https://iplay.163.com/hot (网易LOOK直播网站)

1.首先分析页面,发现获取主播的数据接口请求是加密的,通过下滑出发JS发送请求。不想分析
2.采用selenium 模拟 下滑(问题)
3.配置selenium 不加载图片(省去不必要的时间)

chrome_options = webdriver.ChromeOptions()
prefs = {
    'profile.default_content_setting_values': {
         'images': 2,
        'javascript': 2
    }
}
chrome_options.add_experimental_option('prefs', prefs)
  1. 等待元素出现执行操作
WebDriverWait(driver, 20).until(lambda driver:driver.find_element_by_css_selector('.price > strong'))

准备用去执行js模拟下滑

var q=document.documentElement.scrollTop=10000;
self.driver.execute_script(js)

但是发现就一直无效,经过摸索这个是针对html节点的
总结方法:
6. 如果滚动条是针对整个HTML可以用如下方式:

js = "var q=document.documentElement.scrollTop=10000"  # documentElement表示获取根节点元素
self.driver.execute_script(js)
  1. 如果滚动条是针对整个body可以用如下方式:
js = "var q=document.body.scrollTop=10000"  # documentElement表示获取body节点元素
self.driver.execute_script(js)
  1. 如果滚动条是针对某个div可以用如下方式:该页面的滚动条就是针对class='main’的div而言的
js = "var q=document.getElementsByClassName('main')[0].scrollTop = 10000"  # getElementsByClassName表示获取class='main'的元素列表,0表示第一个,所以使用的时候要加索引
self.driver.execute_script(js)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值