搜索

首页  >  问答  >  正文

Python爬虫如何爬取span和span中间的内容并分别存入字典里?

我想把房屋概况分别抓出来并分别作为独立的列存储进字典里,但是行内元素没有办法直接用for循环抠出来。
这是我的代码:

soup.select('.house-info li')[1].text.strip()

这是网页html代码:

<li><span class="info-tit">房屋概况:</span>住宅
                        <span class="splitline">|</span>1室1厅1卫
                        
                        <span class="splitline">|</span><span title="建筑面积">46m²</span>
                        
                        <span class="splitline">|</span> (高层)/共18层
                        
                        <span class="splitline">|</span>南北
                        
                        <span class="splitline">|</span> 豪华装修
                        
                    </li>
phpcn_u1582phpcn_u15822800 天前2164

全部回复(5)我来回复

  • 曾经蜡笔没有小新

    曾经蜡笔没有小新2017-05-18 10:54:42

    其实还是很有简单的,你看这个还是有规律的,规律在于有分隔符|,我写了个DEMO

    something  = '''<li><span class="info-tit">房屋概况:</span>住宅  <span class="splitline">|</span>1室1厅1卫<span class="splitline">|</span><span title="建筑面积">46m²</span><span class="splitline">|</span> (高层)/共18层
    
                            <span class="splitline">|</span>南北
    
                            <span class="splitline">|</span> 豪华装修
    
                        </li>''';
    
    soup  = BeautifulSoup(something, 'lxml')
    plaintext = soup.select('li')[0].get_text().strip()

    通过get_text()得到内在所有内容,然后去除空格。后面你就用split进行分割吧,后面的不写了。
    如果有问题再交流。

    回复
    0
  • 给我你的怀抱

    给我你的怀抱2017-05-18 10:54:42

    我感觉这个html代码写错了呢,标签的内容文本在标签外面

    正确的标签内容就两个:

    • 房屋概况:

    • 46m²

    回复
    0
  • 巴扎黑

    巴扎黑2017-05-18 10:54:42

    内部文字

    回复
    0
  • 滿天的星座

    滿天的星座2017-05-18 10:54:42

    你这种情况,我觉得用 for 循环加上正则表达式是最方便的,如果所有模版都是这样固定的话

    回复
    0
  • 黄舟

    黄舟2017-05-18 10:54:42

    用pyquery吧

    从 pyquery 导入 PyQuery 作为 Q

    Q(text).find('.house-info li').text()

    回复
    0
  • 取消回复