为什么:
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)可以打印所有元素
根据评论,看起来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]