Python爬虫笔记(六)(1)selenium的三种等待

本文介绍了Python爬虫中使用selenium进行网页交互时的三种等待方式:强制等待、隐式等待和显式等待。重点讲解了显式等待的创建步骤,帮助读者理解如何更好地控制网页元素加载。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

selenium的三种等待:

1.强制等待:不管页面是否加载出来,强制让金晨等待。

	time.sleep(2)

2.隐式等待:

	driver.implicity_wait(20)
	设置20秒的最大等待时长,等待的结束条件是:
		等待到浏览器全部加载完成为止。
		(全部加载可以理解为,浏览器不再转圈。)
	弊端:页面的加载其实不单单是页面html,重要的是还有一些静态资源,
		而静态资源的加载是最耗时的。这些静态资源对于我们爬取数据又没什么作用,
		所以隐式等待其实效率并不高。

3.显示等待:

	满足一些内置的等待条件,只要这些条件满足,就等待结束。
		(这些条件比如:特定页面元素加载出来。)

创建显示等待的步骤:

			from selenium.webdriver.support.wait import WebDriverWait
			from selenium.webdriver.support import expected_conditions as EC
			from selenium.webdriver.common.by import By
			1.创建wait对象:
				wait = WebDriverWait(
					driver = 作用的哪个驱动,
					20,最大等待时长
					0.5,每隔几秒做页面扫描
				)
			2.在之前的selenium使用步骤的等待位置:
				wait.until(EC.presence_of_element_located(locator=定位器对象))
				——》返回值是一个webelement对象(locator对象所定位的哪个webelement)
				定位器对象是一个元组。
				locator = (By.xpath,'xpath表达式')
						By.ID
						By.CSS_SELECTOR
				文档:selenium的三种等待.note
				(链接:http://note.youdao.com/noteshare?id=8f6a0765e4017a4140a05485a9d80a48&sub=48D9761ED13A49EDAC64D180C8340613)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值