gpt4 book ai didi

python - 使用 Python Selenium 获取跨度文本

转载 作者:太空狗 更新时间:2023-10-29 17:01:22 25 4
gpt4 key购买 nike

这应该很容易,但我做不到。我正在使用 Google 主页运行一个小演示作为测试。

这是我的脚本:

from selenium import webdriver
from selenium.common.exceptions import NoSuchElementException
from selenium.webdriver.common.keys import Keys
import time

browser = webdriver.Chrome()
browser.get("http://www.google.com") # Load page

time.sleep(0.2)

#top nav elements
elems = browser.find_elements_by_xpath("//span[contains(@class, 'gbts')]")

for e in elems:
print e.get_attribute('text')

browser.close()

它返回:

None
None
None
None
None
None
None
None
None
None
None

所以我认为它捕获了正确的元素,但也许不是正确的属性?没有把握。我也尝试打印 e.text() 但吐出来了:

Traceback (most recent call last):
File "sample.py", line 14, in <module>
print e.text()
TypeError: 'unicode' object is not callable

有什么想法吗?

*编辑 - 可能的解决方案? *

e.get_attribute('innerHTML') seems to work.

最佳答案

应该这样做:

from selenium import webdriver
browser = webdriver.Firefox()
browser.get("http://www.google.com")
for elem in browser.find_elements_by_xpath('.//span[@class = "gbts"]'):
print elem.text

textWebElement 类的属性,因此不可调用。

class WebElement(object):
"""Represents an HTML element.
...
...

@property
def text(self):
"""Gets the text of the element."""
return self._execute(Command.GET_ELEMENT_TEXT)['value']

您有两种选择来获得第三场比赛:

#  1. Modify your xpath expression
browser.find_elements_by_xpath('(.//span[@class = "gbts"])[3]')[0].text

# 2. Access it by list index
browser.find_elements_by_xpath('.//span[@class = "gbts"])')[2].text

关于python - 使用 Python Selenium 获取跨度文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14590341/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com