Извините, если вам кажется, что это было задано, но я прочитал связанные вопросы и был совершенно новым для Python. Я не мог найти, как написать этот запрос в чистом виде.
На данный момент у меня есть этот минимальный код Python:
from mechanize import Browser
from BeautifulSoup import BeautifulSoup
import re
import urllib2
br = Browser()
br.open("http://www.atpworldtour.com/Rankings/Singles.aspx")
filename = "rankings.html"
FILE = open(filename,"w")
html = br.response().read();
soup = BeautifulSoup(html);
links = soup.findAll('a', href=re.compile("Players"));
for link in links:
print link['href'];
FILE.writelines(html);
Он извлекает всю ссылку, где href содержит слово player.
Теперь HTML, который нужно разборки, выглядит примерно так:
<tr>
<td>1</td>
<td><a href="/Tennis/Players/Top-Players/Roger-Federer.aspx">Federer, Roger</a> (SUI)</td>
<td><a href="/Tennis/Players/Top-Players/Roger-Federer.aspx?t=rb">10,550</a></td>
<td>0</td>
<td><a href="/Tennis/Players/Top-Players/Roger-Federer.aspx?t=pa&m=s">19</a></td>
</tr>
1 содержит ранг игрока. Я хотел бы получить эти данные в словаре:
Не могли бы вы дать мне несколько указателей или если это достаточно легко, помогите мне построить кусок кода? Я не уверен, как сформулировать запрос в Beautiful Soup.
Энтони
Поиск игроков, использующих ваш метод, будет работать, но вернет 3 результата на игрока. Легче выполнять поиск самой таблицы, а затем перебирать строки (кроме заголовка):
table=soup.find('table', 'bioTableAlt')
for row in table.findAll('tr')[1:]:
cells = row.findAll('td')
#retreieve data from cells...
Чтобы получить нужные данные:
rank = cells[0].string
player = cells[1].a.string
link = cells[1].a['href']