使用selenium对网页发起请求
# 导入webdriver
from selenium import webdriver
# 创建一个浏览器对象
browser = webdriver.Chrome()
# 使用浏览器对象对网址发起请求
browser.get('url')
selenium的定位单个节点
# 通过id值匹配
res = browser.find_element_by_id(' ')
# 通过name值匹配
res = browser.find_element_by_name(' ')
# 通过class属性值匹配
res = browser.find_element_by_class_name('')
# 通过css选择器匹配
res = browser.find_element_by_css_selector('')
# 通过xpath语法匹配
res = browser.find_element_by_xpath(' ')
# 通过标签名匹配
res6=browser.find_element_by_tag_name("")
# 通过文本链接匹配
res7=browser.find_element_by_link_text("新闻")
# 针对一些比较长的文本链接,取其中的一小部分文本值进行匹配
res8=browser.find_element_by_partial_link_text("贴")
# 退出
browser.quit()
定位多个节点只需要把element变为elements即可
获取标签的属性值和文本
attriubute=browser.find_element_by_name("tj_trnews").get_attribute("href")
text=browser.find_element_by_name("tj_trnews").text
a_list=browser.find_elements_by_class_name("mnav")
鼠标点击事件
1.click():单击鼠标左键
2.double_click():鼠标左键双击
3.context_click():鼠标右键单击
4.click_and_hold():点击鼠标左键,不松开
5.release():松开鼠标左键
#定义一个ActionChains类的对象,参数是浏览器对象
#ActionChains类,需要一个参数:浏览器对象。当调用相关鼠标操做函数的时候,这些事情并不会立刻执行,而是将所有的鼠标事件都放入到了一个队列当中,只有执行perform函数的时候,所有的鼠标事件才会被执行。
action=ActionChains(browser)
click_me=browser.find_element_by_xpath('//input[@value="click me"]')
double_click=browser.find_element_by_xpath('//input[@value="dbl click me"]')
right_click_me=browser.find_element_by_xpath('//input[@value="right click me"]')
action.click(click_me)
action.double_click(double_click)
action.context_click(right_click_me)
action.perform()
鼠标移动事件
# move_element=browser.find_element_by_xpath('//input[@value="Write on hover"]')
# action.move_to_element(move_element)
# action.perform()
鼠标拖拽事件
#drag_and_drop():拖拽到某个元素然后松开
#drap_and_drop_by_offset(source,x,y):拖拽到距离某个坐标点多少的位置然后松开
browser=webdriver.Chrome()
browser.maximize_window()
browser.get("http://sahitest.com/demo/dragDropMooTools.htm")
time.sleep(3)
#首先要找到被拖拽元素
dragger=browser.find_element_by_id("dragger")
#找到要被拖拽到的元素位置
target1=browser.find_element_by_xpath('//div[text()="Item 1"]')
target2=browser.find_element_by_xpath('//div[text()="Item 2"]')
target3=browser.find_element_by_xpath('//div[text()="Item 3"]')
target4=browser.find_element_by_xpath('//div[text()="Item 4"]')
action=ActionChains(browser)
#方式一:
# action.drag_and_drop(dragger,target1)
# action.drag_and_drop(dragger,target2)
# action.drag_and_drop(dragger,target3)
# action.drag_and_drop(dragger,target4)
#方式二:
# action.click_and_hold(dragger).move_to_element(target1).release()
#方式三:
action.click_and_hold(dragger).release(target1)
action.perform()