iT邦幫忙

0

爬蟲scrapy去除無內容的tag

  • 分享至 

  • xImage

目前在抓取udn新聞裡面完整的內容

是使用BeautifulSoup和scrapy來抓取

在抓取時遇到一個問題,就是目標tag中,有些tag底下是沒有內容的

舉例來說,新聞內容都放在<div> class="article"底下的<p>裡面
https://ithelp.ithome.com.tw/upload/images/20210513/201194346x07rFv49A.png

但是其中會出現像上圖中第一個tag,<p></p>這樣裡面是沒有內容的
或者是下像圖中<P></p>是在不同行
https://ithelp.ithome.com.tw/upload/images/20210513/20119434MXjo1SHDoB.png

由於這樣會讓印出來的內容每個段落中間多空了2行

想請問有沒有方法可以將沒有內容的<p>去除?

執行結果:
https://ithelp.ithome.com.tw/upload/images/20210513/201194346yCZHs3VZ6.png
同事整合後的執行結果:
https://ithelp.ithome.com.tw/upload/images/20210513/20119434KdbVOfAHMO.png
PS: 有試過用if tag.get_text() != None:
None替換成""、"\n"、"\r"、"\r\n" ...@#$% 都不行...
len(tag.get_text())判斷長度不等於0 也不行...
.replace() .strip()也沒辦法做到完全去除...

程式碼:

import scrapy
import json
from bs4 import BeautifulSoup


class UdnCrawler(scrapy.Spider):
    name = 'udn'
    start_urls = (['https://stars.udn.com/star/story/10091/5407836'])

    def parse(self, response):
        res = BeautifulSoup(response.body)
        section = ""
        for tag in res.select('div.article p'):
            children = tag.findChild()
            if children == None:
                section += tag.get_text()
                section += "\n"
        article = {'content': section}
        jsondata = json.dumps(article, ensure_ascii=False)
        print(jsondata)
聰明貓 iT邦新手 3 級 ‧ 2021-05-13 18:19:30 檢舉
.................................................
我知道為什麼怎麼做都會空兩行了
因為有內容的tag裡面,自己開頭就先空一行了...
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

1 個回答

1
koro_michael
iT邦新手 2 級 ‧ 2021-05-13 18:24:00
import re

text1 = '<p>    </p>';
text2 = '''<p>



</p>''';
print(text1)
print(re.sub(r'<p>\s*</p>', '', text1))
print(text2)
print(re.sub(r'<p>\s*</p>', '', text2))

用正則把空的p去掉

聰明貓 iT邦新手 3 級 ‧ 2021-05-26 16:38:10 檢舉

還不懂正則,再找時間研究一下

我要發表回答

立即登入回答