本文详细介绍了Playwright的常用操作方法,包括获取页面元素、点击按钮和链接、获取标签页、获取元素属性、设置超时、单击元素、模拟鼠标点击和拖放操作等。这些方法可以帮助开发者更加高效地进行自动化测试和爬虫开发。
可以使用 BrowserContext.cookies() 方法来获取特定的Cookie。如果没有指定参数,将返回所有Cookie。
all_cookies=browser_context.cookies()
可以使用page.locator()方法并指定a表达式来获取页面所有的链接。
print(f”{page_elements.count()} link/links are found.”)
使用page.locator()方法并指定 a:has-text() 表达式来获取页面的所有链接。
print(f”{page_elements.count()} link/links are found.”)
点击按钮的基本思路就是使用click()方法。
element.click()
和按钮一样, 主体思路还是使用click()方法。 注意, 和按钮不同的是,link元素的定位需要选择第一个元素。
element.click()
现在的浏览器都是支持多个标签页的。 那么我们可以采用BrowserContext.pages属性来获取所有的打开页面。
opened_pages=context.pages
# 枚举所有的打开页面的url
for p in opened_pages:
print(p.url)
可以使用locator.evaluate()方法执行Javascript表达式, 获取元素的所有属性名。 并枚举他们,并使用get_attribute()方法获得每个属性的值。
element=page.locator(‘img_tdouya’).first
# 获得所有的属性
el_attrs=element.evaluate(“el=> el.getAttributeNames()”)
# 枚举所有的属性名称和值
for attr in el_attrs:
print(attr, “:”, element.get_attribute(attr))
虽然Playwright的超时要比Selenium友好的多。 但是,必要的时候也可以设置。 尤其是一些严苛环境下。
page.click(“#tdouyaButton”, timeout=60000)
在本小结中, 我们探索的情形是元素有可能存在有可能不存在。 整体思路是综合利用上面提到过的page.locator()方法。检查元素数量。 如果大于0, 则进行后续点击操作。
elements=page.locator(‘a:has-text(“田辛老师”)’)
# 获得元素数量
link_number=elements.count()
# 元素数量大于0, 则进行点击操作
if link_number > 0:
elements.first.click()
使用page.mouse.click()方法来点击页面中特定位置的元素。
使用page.mouse.move实现拖动, 使用page.mouse.up()、page.mouse.down()方法模拟鼠标左键长按和放开的操作。
page.mouse.down()
page.mouse.move(300, 300)
page.mouse.up()
到此这篇关于Python中Playwright的常用操作方法分享的文章就介绍到这了,更多相关Python Playwright内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!