Selenium.webdriver属性大全,常用属性以及获取元素属性值方法的介绍

首先用一段简短的代码查看Selenium.webdriver的所有属性

from selenium import webdriver  # 导入webdriver包
browser=webdriver.Firefox() # 初始化一个火狐浏览器实例:driver
print( dir(browser) )  #获取所有属性名

红色字体为常用的方法!

['CONTEXT_CHROME', 'CONTEXT_CONTENT', 'NATIVE_EVENTS_ALLOWED', '__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__enter__', '__eq__', '__exit__', '__format__', '__ge__', '__getattribute__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', '_file_detector', '_is_remote', '_mobile', '_switch_to', '_unwrap_value', '_web_element_cls', '_wrap_value', 'add_cookie', 'application_cache', 'back', 'binary', 'capabilities', 'close', 'command_executor', 'context', 'create_web_element', 'current_url', 'current_window_handle', 'delete_all_cookies', 'delete_cookie', 'desired_capabilities', 'error_handler', 'execute', 'execute_async_script', 'execute_script', 'file_detector', 'file_detector_context', 'find_element', 'find_element_by_class_name', 'find_element_by_css_selector', 'find_element_by_id', 'find_element_by_link_text', 'find_element_by_name', 'find_element_by_partial_link_text', 'find_element_by_tag_name', 'find_element_by_xpath', 'find_elements', 'find_elements_by_class_name', 'find_elements_by_css_selector', 'find_elements_by_id', 'find_elements_by_link_text', 'find_elements_by_name', 'find_elements_by_partial_link_text', 'find_elements_by_tag_name', 'find_elements_by_xpath', 'firefox_profile', 'forward', 'fullscreen_window', 'get', 'get_cookie', 'get_cookies', 'get_log', 'get_screenshot_as_base64', 'get_screenshot_as_file', 'get_screenshot_as_png', 'get_window_position', 'get_window_rect', 'get_window_size', 'implicitly_wait', 'install_addon', 'log_types', 'maximize_window', 'minimize_window', 'mobile', 'name', 'orientation', 'page_source', 'profile', 'quit', 'refresh', 'save_screenshot', 'service', 'session_id', 'set_context', 'set_page_load_timeout', 'set_script_timeout', 'set_window_position', 'set_window_rect', 'set_window_size', 'start_client', 'start_session', 'stop_client', 'switch_to', 'switch_to_active_element', 'switch_to_alert', 'switch_to_default_content', 'switch_to_frame', 'switch_to_window', 'title', 'uninstall_addon', 'w3c', 'window_handles']
 

常用方法说明:

  1. driver.find_element_by_class_name:通过class样式的名称获取想要的内容
  2. dirver.find_element_by_id:通过id的名称获取想要的内容
  3. driver.find_element_by_link_text:通过输入的文本内容获取对应的链接
  4. driver.find_element_by_css_selector:通过css样式的名称获取想要的内容
  5. driver.find_element_by_tag_name:通过标签的的名称获取想要的内容
  6. driver.find_element_by_xpath:用过某个标签的xpath路径获取想要的内容
  7. driver.current_url:用于获得当前页面的URL
  8. driver.title:用于获取当前页面的标题
  9. driver.page_source:用于获取页面html源代码
  10. driver.current_window_handle:用于获取当前窗口句柄
  11. driver.window_handles:用于获取所有窗口句柄
  12. driver.get(url):浏览器加载url。
  13. 实例:driver.get("http//:www.baidu.com")
  14. driver.switch_to_frame(id或name属性值):切换到新表单(同一窗口)。若无id或属性值,可先通过xpath定位到iframe,再将值传给switch_to_frame()
  15. driver.switch_to_window(窗口句柄):切换到新窗口
  16. driver.execute_script(js):执行脚本命令

以下代码,进一步了解以上常用方法中怎样进行元素查找

# -*- coding: utf-8 -*-
"""
Created on Sat Apr 13 20:41:41 2019

@author: 郭展鹏
"""
from selenium import webdriver
from selenium.webdriver.common.by import By
browser=webdriver.Firefox()
browser.get( 'https://www.taobao.com' )  #访问淘宝的界面

input_first=browser.find_element_by_id( 'q' ) #通过id查找
#两种不同的方法,该方法需要from selenium.webdriver.common.by import By
input_first=browser.find_element( By.ID,'q' ) #通过id查找  

input_second=browser.find_element_by_css_selector('#q')  #通过css样式查找
input_second=browser.find_element( By.CSS_SELECTOR,'#q' )
                                  
input_third=browser.find_element_by_xpath( '//*[@id="q"]' )  #通过xpath路径查找

以下代码,进一步了解以上常用方法中窗口内、窗口间的操作

# -*- coding: utf-8 -*-
"""
Created on Sat Apr 13 20:50:05 2019

@author: 郭展鹏
"""
from selenium import webdriver
from selenium.webdriver.common.keys import Keys
import time
browser=webdriver.Firefox()
browser.get( 'https://www.baidu.com' )
input=browser.find_element_by_id( 'kw' )  #找到Id=kw的位置
input.send_keys( 'Python' ) #输入Python并进入
browser.execute_script( 'alert("hello world")' )  #进入由Python关键字打开的页面后弹出 “hello world”的窗口
time.sleep(2)
input.clear()

input.send_keys( 'java' )
input.send_keys( Keys.ENTER )
print( browser.page_source )  #获取html页面代码
print( browser.current_url ) #获取当前页面的url地址
time.sleep(2)

browser.close()
browser.quit()
import time
from selenium import webdriver # 导入webdriver包

driver=webdriver.Firefox() # 初始化一个火狐浏览器实例:driver

driver.get( 'https://www.baidu.com' ) #通过get的方式,打开百度的网址
driver.execute_script( 'window.open()' )  #执行脚本命令,打开一个新窗口
time.sleep(3) #进程挂起的时间 这里为程序运行等待3秒钟
driver.switch_to.window( browser.window_handles[1] )  #切换到新窗口
driver.get( 'https://www.baidu.com' )  #在新窗口打开百度的界面
time.sleep(3) #进程挂起的时间 这里为程序运行等待3秒钟
driver.switch_to.window( browser.window_handles[0] ) #创建一个句柄,进入第一个窗口
driver.get( 'https://www.zhihu.com' ) #在第一个窗口打开知乎的界面
time.sleep(3) #进程挂起的时间 这里为程序运行等待3秒钟

driver.close()   #关闭浏览器
driver.quit()  #停止进程

以下代码为浮动窗口内标签的操作-拖拽,以http://www.runoob.com/try/try.php?filename=jqueryui-api-droppable网址的html为例子 

详细操作可以参考网址:https://www.cnblogs.com/cnkai/p/7538267.html(转载!!!)

# -*- coding: utf-8 -*-
"""
Created on Sat Apr 13 21:10:00 2019

@author: 郭展鹏
"""

from selenium import webdriver
#Action Chains类常用于模拟鼠标的行为,比如单击,双击,拖拽等行为,使用下面的方法导入Action Chains类
from selenium.webdriver import ActionChains

browser=webdriver.Firefox()
url='http://www.runoob.com/try/try.php?filename=jqueryui-api-droppable'
browser.get(url)
browser.switch_to_frame( 'iframeResult' ) #切换到 浮动框架页面
source=browser.find_element_by_id('draggable')
target=browser.find_element_by_id('droppable')

actions=ActionChains(browser)
actions.drag_and_drop( source,target )  #从source拖拽到target
actions.perform()

browser.close()
browser.quit()

 

你可能感兴趣的:(爬虫)