python+selenium学习笔记
查找页面元素
id find_element_by_id()
name find_element_by_name()
class_name find_element_by_class_name()
tag_name find_element_by_tag_name() #通过标签名,如find_element_by_tag_name('div')
定位a标签(超文本链接)
link text partial
find_element_by_link_text() 需要完整的输入链接文本内容,不完整则会报错
find_element_by_partial_link_text() 输入链接文本的部分内容
CSS查找器
.classname 选择类名为classname的所有元素
#id 选择指定id的元素
element 选择所有指定元素,如p 指选择所有\<p\>元素
element1,element2 选择所有两种元素
element1 element2 选择element1元素下的所有element2元素
element1>element2 选择父元素为element1的所有element2元素
element1+element2 选择紧接在element1之后的所有element2元素
[attribute] 选择有属性attribute的所有元素
[attribute=value] 选择指定attribute属性值的所有元素
xpath (xml path) xml可扩展标记语言 html超文本标记语言
node_name 选取此节点的所有子节点。
/ 绝对路径匹配,从根节点选取。
// 相对路径匹配,从所有节点中查找当前选择的节点,包括子节点和后代节点,其第一个 / 表示根节点。
. 选取当前节点。
.. 选取当前节点的父节点。
@ 选取属性值,通过属性值选取数据。常用元素属性有 @id 、@name、@type、@class、@tittle、@href。
代码:
from selenium import webdriver
import time
from selenium.webdriver.common.keys import Keys
#创建webdriver对象(如果把驱动配置到系统环境变量中,则不需要带参创建)
driver = webdriver.Chrome("chromedriver.exe")
url = "https://www.baidu.com"
driver.get(url) #使用浏览器打开网页
##使用cookie实现登录
driver.add_cookie({"name":"BDUSS","value":"登陆后,右击,检查,newwork,刷新,点击www.baidu.com查看"})
driver.add_cookie({'name':'BAIDUID','value':'登陆后,右击,检查,newwork,刷新,点击www.baidu.com查看'})
driver.find_element_by_id("kw").send_keys("哈哈哈哈哈") #,元素定位,通过网页元素id查找元素,并输入内容
driver.find_element_by_id("su").click() #找查id为"su"的元素,并点击
driver.implicitly_wait(10) #隐式等待,等待网页加载完成再执行下一句
time.sleep(3)
####下拉滚动条到最低端
js_scroll = 'window.scrollTo(0,document.body.scrollHeight)' #滚动到底部
driver.execute_script(js_scroll)
##下拉10000个像素
##js = "document.documentElement.scrollTop=10000"
##driver.execute_script(js)
####自动下拉到div_page元素可见,滚动条下拉到最后
##div_page = driver.find_element_by_id("page") #页面最下面的元素,换页div
##driver.execute_script("arguments[0].scrollIntoView();",div_page)
#通过xpath路径查找元素,从任意地方开始,先找到属性id=“1”的元素,再找其子元素div,再往下找第一个子元素div,再往下找h3,再找大h3的子元素a为止
driver.find_element_by_xpath('//*[@id="1"]/div/div[1]/h3/a').click()
#在当前页面截图,并保存到文件“image/pitrue.jpg”,图片能成功保存,但会报错:
#name used for saved screenshot does not match file type. It should end with a `.png` extension
##driver.get_screenshot_as_file("image/pictrue.jpg")
#所以保存图片尽量使用.png格式,不会报错
driver.get_screenshot_as_file("image/pictrue_0.png") #如果文件已经存在,则会被覆盖
handles = driver.window_handles #获取当前driver所在的窗口,返回一个列表
current = driver.current_window_handle #获取浏览器的所有窗口
print("所有窗口:",handles,end = '\n')
print("当前窗口:",current,end = '\n')
#将driver所在窗口切换到第二个窗口
driver.switch_to.window(handles[1])
driver.get_screenshot_as_file("image/pictrue_1.png") #截图
print("切换后的窗口为:",driver.current_window_handle,end ='\n')
driver.implicitly_wait(10)
#通过scc查找器查找元素
##driver.find_element_by_css_selector(".J-audio-text").click()
#下面一条语句中元素在代码中的类名为 class = 'cmn-icon wiki-lemma-icons wiki-lemma-icons_edit-lemma',查找要将空格换成.
##driver.find_element_by_css_selector(".cmn-icon.wiki-lemma-icons.wiki-lemma-icons_edit-lemma").click()
##driver.find_element_by_link_text("编辑").click() #与上一条语句查找与元素相同
driver.find_element_by_css_selector(".lemma-discussion.cmn-btn-hover-blue.cmn-btn-28.j-discussion-link").click()
driver.switch_to.window(driver.window_handles[2]) #切换到第三个窗口
driver.implicitly_wait(10) #等待页面加载完成
##driver.find_element_by_class_name("issue-form-input").click()
driver.find_element_by_class_name("issue-form-input").send_keys("哈哈哈哈哈哈")
##### 给textarea元素赋值
#1、通过send_keys()赋值
##driver.find_element_by_class_name('issue-form-textarea.auto-textarea').send_keys("床前明月光,疑似地上霜。\n举头望明月,低头思故乡。")
#2、通过执行javascript代码来赋值
#下面的代码会报错:javascript error: Invalid or unexpected token
##js_txt = 'var ta = document.getElementsByTagName("textarea");ta[0].value = "床前明月光,疑似地上霜。\n举头望明月,低头思故乡。"'
##driver.execute_script(js_txt)
#下面的不会报错,把需要处理的字符传到js,让js来处理 '\n'
js_txt = 'var ta = document.getElementsByTagName("textarea");ta[0].value = arguments[0]'
driver.execute_script(js_txt,"床前明月光,疑似地上霜。\n举头望明月,低头思故乡。")
#### 上传图片,通过send_keys('图片文件名')
driver.find_element_by_css_selector('.issue-btn-item.add-issue-image .wgt-picUploader-wrapper form input').send_keys("F:\\pythonWorkspace\\AutomatedTesting\\image\\pictrue_1.png")
driver.find_element_by_css_selector('.issue-btn-item.add-issue-image .wgt-picUploader-wrapper form input').send_keys("F:\\pythonWorkspace\\AutomatedTesting\\image\\pictrue_0.png")
time.sleep(3)