BeautifulSoup,HTML表中的字典
发布于 2021-01-29 18:14:10
我正在尝试从网站上抓取表格数据。
这是一个简单的示例表:
t = '<html><table>' +\
'<tr><td class="label"> a </td> <td> 1 </td></tr>' +\
'<tr><td class="label"> b </td> <td> 2 </td></tr>' +\
'<tr><td class="label"> c </td> <td> 3 </td></tr>' +\
'<tr><td class="label"> d </td> <td> 4 </td></tr>' +\
'</table></html>'
所需的解析结果是 {' a ': ' 1 ', ' b ': ' 2 ', ' c ': ' 3 ', ' d ' : ' 4' }
到目前为止,这是我最接近的尝试:
for tr in s.findAll('tr'):
k, v = BeautifulSoup(str(tr)).findAll('td')
d[str(k)] = str(v)
结果是:
{'<td class="label"> a </td>': '<td> 1 </td>', '<td class="label"> d </td>': '<td> 4 </td>', '<td class="label"> b </td>': '<td> 2 </td>', '<td class="label"> c </td>': '<td> 3 </td>'}
我知道的text=True
参数,findAll()
但是使用它时没有得到预期的结果。
我正在使用python 2.6和BeautifulSoup3。
关注者
0
被浏览
51
1 个回答
-
尝试这个:
from BeautifulSoup import BeautifulSoup, Comment t = '<html><table>' +\ '<tr><td class="label"> a </td> <td> 1 </td></tr>' +\ '<tr><td class="label"> b </td> <td> 2 </td></tr>' +\ '<tr><td class="label"> c </td> <td> 3 </td></tr>' +\ '<tr><td class="label"> d </td> <td> 4 </td></tr>' +\ '</table></html>' bs = BeautifulSoup(t) results = {} for row in bs.findAll('tr'): aux = row.findAll('td') results[aux[0].string] = aux[1].string print results