这是我试图回答的问题。我只在google主页的搜索框上测试过。我利用@alecxe 上面关于'outerHTML' 的回答获得了html,我使用正则表达式([a-z]+-?[a-z]+_?)='?"? 来匹配属性名称。我认为只需要修改正则表达式以匹配越来越多的案例。但我们需要的基本名称是“等号后面的任何内容”。
给定一个 webElement
def get_web_element_attribute_names(web_element):
"""Get all attribute names of a web element"""
# get element html
html = web_element.get_attribute("outerHTML")
# find all with regex
pattern = """([a-z]+-?[a-z]+_?)='?"?"""
return re.findall(pattern, html)
在下面的代码上测试一下
import re
from selenium import webdriver
driver = webdriver.Firefox()
google = driver.get("http://www.google.com")
driver.find_element_by_link_text("English").click()
search_element = driver.find_element_by_name("q")
get_web_element_attribute_names(search_element)
输出:
['class', 'id', 'maxlength', 'name', 'autocomplete', 'title', 'value', 'aria-label', 'aria-haspopup', 'role', 'aria-autocomplete', 'style', 'dir', 'spellcheck', 'type']