BeautifulSoup如何解析HTML的问题

#-*- coding:utf-8 -*-
from bs4 import BeautifulSoup
html_doc = """
<!DOCTYPE html>
<html lang="en" xmlns="http://www.w3.org/1999/xhtml">
<head>
    <meta charset="utf-8" />
    <title>New Document</title>
</head>
<body>
    <div class="tab-pane active" id="all-school-box">
        <div class="col-md-12 table-list">
            <table class="table table-bordered">
                <tr>
                    <td class="col-md-1"><strong>学校名</strong></td>
                    <td class="col-md-3">北京大学</td>
                    <td class="col-md-1"><strong>联系人</strong></td>
                    <td class="col-md-3">路人甲</td>
                    <td class="col-md-1"><strong>联系电话</strong></td>
                    <td>13800138000</td>
                </tr>
                <tr>
                    <td><strong>城市</strong></td>
                    <td>北京</td>
                    <td><strong>状态</strong></td>
                    <td>正常</td>
                    <td><strong>加入时间</strong></td>
                    <td>0000-00-00</td>
                </tr>
                <tr>
                    <td><strong>学生<br>(总数 / 正常)</strong></td>
                    <td>5961 / 4761</td>
                    <td><strong>学生B部<br>(总数 / 正常)</strong></td>
                    <td>5961 / 4761</td>
                    <td><strong>学生C部<br>(总数 / 正常)</strong></td>
                    <td>0 / 0</td>
                </tr>
            </table>
        </div>
    </div>
</div>
</body>
</html>
"""
soup = BeautifulSoup(html_doc, 'lxml')

print(soup.prettify())

思路
这种是可以转换为json?
还是直接正则过滤出数字?

我需要5961 / 4761 分开输出
转换为str格式
5961
4761

阅读 3.4k
2 个回答

直接正则好了,简单粗暴:

pattern = re.compile(r'<td>(\d+) / (\d+)</td>')
m = pattern.findall(html_doc)
for item in m:
    print(item[0])
    print(item[1])

不是json,它解析HTML文档,并且类似浏览器一样构建了一个节点树,所以你可以使用CSS Selector语法,利用find_all/find 函数获得tag节点,然后在你要获取数据的节点上调用 get_text(),返回的应该是一个str,然后调用 split("/")。
个人思路。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题