В настоящее время я работаю над веб-скребком, который позволит мне получать статистику от футболиста.Обычно это было бы легкой задачей, если бы я мог просто взять div, однако, этот сайт использует атрибут под названием data-stats и использует его как класс.Это пример этого.
<th scope="row" class="left " data-stat="year_id"><a href="/years/2000/">2000</a></th>
Если вы хотите проверить сайт самостоятельно, вот ссылка.
https://www.pro -football-reference.com / Players / B / BradTo00.htm
Я пробовал несколько разных методов.Либо это не будет работать вообще, либо я смогу запустить цикл for и начать помещать вещи в массивы, однако вы заметите, что не все в таблице имеет тот же тип var.
Извините за форматирование и грамматику.
Вот то, что у меня есть, я уверен, что это не самый красивый код, это в основном просто код, который я пробовал самостоятельнои несколько вещей смешались с поиском в Google.Проигнорируйте случайный импорт, я пробовал разные вещи
# import libraries
import csv
from datetime import datetime
import requests
from bs4 import BeautifulSoup
import lxml.html as lh
import pandas as pd
# specify url
url = 'https://www.pro-football-reference.com/players/B/BradTo00.htm'
# request html
page = requests.get(url)
# Parse html using BeautifulSoup, you can use a different parser like lxml if present
soup = BeautifulSoup(page.content, 'lxml')
# find searches the given tag (div) with given class attribute and returns the first match it finds
headers = [c.get_text() for c in soup.find(class_ = 'table_container').find_all('td')[0:31]]
data = [[cell.get_text(strip=True) for cell in row.find_all('td')[0:32]]
for row in soup.find_all("tr", class_=True)]
tags = soup.find(data ='pos')
#stats = tags.find_all('td')
print(tags)