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 个回答
  • 面试哥
    面试哥 2021-01-29
    为面试而生,有面试问题,就找面试哥。

    尝试这个:

    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
    


知识点
面圈网VIP题库

面圈网VIP题库全新上线,海量真题题库资源。 90大类考试,超10万份考试真题开放下载啦

去下载看看