Название очень поясняющее, я ищу каждый класс на странице определенной длины.
Теперь я использую
list=[] #empty array
elements = x.find_elements(By.XPATH,"//*[@class]") #finds out every element that have a class in the page, x is my chromedriver
for element in elements: #inspect every single element found
class = element.get_attribute('class') #filters only the class name
if (len(class)==8): #filters the class name exacy length
list.append(element) #the element is now inside of the list and the loop can ispect next element
Но это ОЧЕНЬ медленно, я думаю, это из-за цикла for. Есть ли у вас какие-либо идеи о том, как искать определенную длину непосредственно внутри функции find_elements или избегать цикла for или любого другого решения, чтобы ускорить это?
Спасибо
9-10 элементов нужной длины, завтра попробуем узнать длину списка найденных элементов
Общее количество первых find_elements составляет 700-800 записей в зависимости от страницы, и процесс занимает почти 30 секунд, чтобы найти все 9-10 классов, которые я ищу.
Разве вы не можете просто использовать регулярное выражение для всего HTML-кода? Затем это найдет ваши классы, после чего вы сможете выполнить конкретный поиск с помощью селена.
Никогда не слышал об этом, можете ли вы объяснить, как это будет работать?
я просто отвечаю на свой вопрос, потому что я думаю, что нашел очень быстрый способ сделать это
я хотел найти имя класса "g" или "g <6alphanumerics>" по какой-то причине в javascript, если вы сделаете document.getElementsByClassName('g'), он найдет все, что мне нужно
Итак, новый фрагмент:
classes = x.execute_script("return document.getElementsByClassName('g')")
возврат важен, иначе массив будет пустым
Вы пробовали регистрировать длину списка
elements
? насколько это велико?