TypeError:slice索引必须是整数或None,或者具有__index__方法python

问题描述 投票:0回答:1

为什么:

k = driver.find_elements_by_class_name("#mw-content-text > div > p:nth-child(3) > b:nth-child(1)")[0:6]

工作

维基的6号(又名titles.text)给出

k = driver.find_elements_by_class_name("#mw-content-text > div > p:nth-child(3) > b:nth-child(1)")[0:titles.text]

错误:

TypeError: slice indices must be integers or None or have an __index__ method

我该如何解决这个问题?为什么这样做呢

代码

cd = webdriver.chrome()
cd.get('https://en.wikipedia.org/wiki/6')
titles = driver.find_elements_by_class_name("#mw-content-text > div > p:nth-child(3) > b:nth-child(1)")
for title in titles:
    print(title.text)

将其更改为int(titles.text)可以打印所有元素

python selenium slice
1个回答
0
投票

根据评论,看起来titles.text的值首先是一个字符串(因此不能用作切片索引)并且等于1 of 6这意味着你将无法直接将它传递给int()转换。

如果你想从字符串中提取6,你首先可以用of分割字符串然后获取最后一个元素。然后,您需要将其转换为整数:

max_pages = int(titles.text.split(" of ")[-1])

k = driver.find_elements_by_class_name("#mw-content-text > div > p:nth-child(3) > b:nth-child(1)")[:max_pages]
© www.soinside.com 2019 - 2024. All rights reserved.