欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

深度剖析使用python抓取網(wǎng)頁(yè)正文的源碼

 更新時(shí)間:2014年06月11日 15:06:47   投稿:hebedich  
平時(shí)打開一個(gè)網(wǎng)頁(yè),除了文章的正文內(nèi)容,通常會(huì)有一大堆的導(dǎo)航,廣告和其他方面的信息。本文的目的,在于說(shuō)明如何從一個(gè)網(wǎng)頁(yè)中提取出文章的正文內(nèi)容,而過(guò)渡掉其他無(wú)關(guān)的的信息。

本方法是基于文本密度的方法,最初的想法來(lái)源于哈工大的《基于行塊分布函數(shù)的通用網(wǎng)頁(yè)正文抽取算法》,本文基于此進(jìn)行一些小修改。

約定:
       本文基于網(wǎng)頁(yè)的不同行來(lái)進(jìn)行統(tǒng)計(jì),因此,假設(shè)網(wǎng)頁(yè)內(nèi)容是沒(méi)有經(jīng)過(guò)壓縮的,就是網(wǎng)頁(yè)有正常的換行的。

       有些新聞網(wǎng)頁(yè),可能新聞的文本內(nèi)容比較短,但其中嵌入一個(gè)視頻文件,因此,我會(huì)給予視頻較高的權(quán)重;這同樣適用于圖片,這里有一個(gè)不足,應(yīng)該是要根據(jù)圖片顯示的大小來(lái)決定權(quán)重的,但本文的方法未能實(shí)現(xiàn)這一點(diǎn)。

       由于廣告,導(dǎo)航這些非正文內(nèi)容通常以超鏈接的方式出現(xiàn),因此文本將給予超鏈接的文本權(quán)重為零。

       這里假設(shè)正文的內(nèi)容是連續(xù)的,中間不包含非正文的內(nèi)容,因此實(shí)際上,提取正文內(nèi)容,就是找出正文內(nèi)容的開始和結(jié)束的位置。     

步驟:

       首先清除網(wǎng)頁(yè)中CSS,Javascript,注釋,Meta,Ins這些標(biāo)簽里面的內(nèi)容,清除空白行。

       計(jì)算每一個(gè)行的經(jīng)過(guò)處理的數(shù)值(1)

       計(jì)算上面得出的每行文本數(shù)的最大正子串的開始結(jié)束位置

其中第二步需要說(shuō)明一下:

       對(duì)于每一行,我們需要計(jì)算一個(gè)數(shù)值,這個(gè)數(shù)值的計(jì)算如下:

              一個(gè)圖片標(biāo)簽img,相當(dāng)于出現(xiàn)長(zhǎng)度為50字符的文本 (給予的權(quán)重),x1,

              一個(gè)視頻標(biāo)簽embed,相當(dāng)于出現(xiàn)長(zhǎng)度為1000字符的文本, x2

              一行內(nèi)所有鏈接的標(biāo)簽 a 的文本長(zhǎng)度 x3 ,

              其他標(biāo)簽的文本長(zhǎng)度 x4

              每行的數(shù)值 = 50 * x1其出現(xiàn)次數(shù) + 1000 * x2其出現(xiàn)次數(shù) + x4 – 8

        //說(shuō)明, -8 因?yàn)槲覀円?jì)算一個(gè)最大正子串,因此要減去一個(gè)正數(shù),至于這個(gè)數(shù)應(yīng)該多大,我想還是按經(jīng)驗(yàn)來(lái)吧。

完整代碼

復(fù)制代碼 代碼如下:

#coding:utf-8
import re

def remove_js_css (content):
    """ remove the the javascript and the stylesheet and the comment content (<script>....</script> and <style>....</style> <!-- xxx -->) """
    r = re.compile(r'''<script.*?</script>''',re.I|re.M|re.S)
    s = r.sub ('',content)
    r = re.compile(r'''<style.*?</style>''',re.I|re.M|re.S)
    s = r.sub ('', s)
    r = re.compile(r'''<!--.*?-->''', re.I|re.M|re.S)
    s = r.sub('',s)
    r = re.compile(r'''<meta.*?>''', re.I|re.M|re.S)
    s = r.sub('',s)
    r = re.compile(r'''<ins.*?</ins>''', re.I|re.M|re.S)
    s = r.sub('',s)
    return s

def remove_empty_line (content):
    """remove multi space """
    r = re.compile(r'''^\s+$''', re.M|re.S)
    s = r.sub ('', content)
    r = re.compile(r'''\n+''',re.M|re.S)
    s = r.sub('\n',s)
    return s

def remove_any_tag (s):
    s = re.sub(r'''<[^>]+>''','',s)
    return s.strip()

def remove_any_tag_but_a (s):
    text = re.findall (r'''<a[^r][^>]*>(.*?)</a>''',s,re.I|re.S|re.S)
    text_b = remove_any_tag (s)
    return len(''.join(text)),len(text_b)

def remove_image (s,n=50):
    image = 'a' * n
    r = re.compile (r'''<img.*?>''',re.I|re.M|re.S)
    s = r.sub(image,s)
    return s

def remove_video (s,n=1000):
    video = 'a' * n
    r = re.compile (r'''<embed.*?>''',re.I|re.M|re.S)
    s = r.sub(video,s)
    return s

def sum_max (values):
    cur_max = values[0]
    glo_max = -999999
    left,right = 0,0
    for index,value in enumerate (values):
        cur_max += value
        if (cur_max > glo_max) :
            glo_max = cur_max
            right = index
        elif (cur_max < 0):
            cur_max = 0

    for i in range(right, -1, -1):
        glo_max -= values[i]
        if abs(glo_max < 0.00001):
            left = i
            break
    return left,right+1

def method_1 (content, k=1):
    if not content:
        return None,None,None,None
    tmp = content.split('\n')
    group_value = []
    for i in range(0,len(tmp),k):
        group = '\n'.join(tmp[i:i+k])
        group = remove_image (group)
        group = remove_video (group)
        text_a,text_b= remove_any_tag_but_a (group)
        temp = (text_b - text_a) - 8
        group_value.append (temp)
    left,right = sum_max (group_value)
    return left,right, len('\n'.join(tmp[:left])), len ('\n'.join(tmp[:right]))

def extract (content):
    content = remove_empty_line(remove_js_css(content))
    left,right,x,y = method_1 (content)
    return '\n'.join(content.split('\n')[left:right])

代碼 從最后一個(gè)函數(shù)開始調(diào)用。

相關(guān)文章

  • 基于python實(shí)現(xiàn)計(jì)算且附帶進(jìn)度條代碼實(shí)例

    基于python實(shí)現(xiàn)計(jì)算且附帶進(jìn)度條代碼實(shí)例

    這篇文章主要介紹了基于python實(shí)現(xiàn)計(jì)算且附帶進(jìn)度條代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03
  • 使用Python來(lái)開發(fā)微信功能

    使用Python來(lái)開發(fā)微信功能

    這篇文章主要介紹了使用Python來(lái)開發(fā)微信功能,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-06-06
  • PyTorch常用函數(shù)torch.cat()中dim參數(shù)使用說(shuō)明

    PyTorch常用函數(shù)torch.cat()中dim參數(shù)使用說(shuō)明

    這篇文章主要為大家介紹了PyTorch常用函數(shù)torch.cat()中dim參數(shù)使用說(shuō)明,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • Python函數(shù)中的全局變量詳解

    Python函數(shù)中的全局變量詳解

    大家好,本篇文章主要講的是Python函數(shù)中的全局變量詳解,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽
    2022-01-01
  • Python利用正則表達(dá)式匹配并截取指定子串及去重的方法

    Python利用正則表達(dá)式匹配并截取指定子串及去重的方法

    這篇文章主要介紹了Python利用正則表達(dá)式匹配并截取指定子串及去重的方法,涉及Python正則表達(dá)式匹配及字符串截取操作的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-07-07
  • 對(duì)Python2與Python3中__bool__方法的差異詳解

    對(duì)Python2與Python3中__bool__方法的差異詳解

    今天小編就為大家分享一篇對(duì)Python2與Python3中__bool__方法的差異詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-11-11
  • 在VScode中引用自定義模塊問(wèn)題

    在VScode中引用自定義模塊問(wèn)題

    這篇文章主要介紹了在VScode中引用自定義模塊問(wèn)題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-07-07
  • Python使用defaultdict解決字典默認(rèn)值

    Python使用defaultdict解決字典默認(rèn)值

    本文主要介紹了Python使用defaultdict解決字典默認(rèn)值,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • Python實(shí)現(xiàn)彈球小游戲的示例代碼

    Python實(shí)現(xiàn)彈球小游戲的示例代碼

    這篇文章主要為大家詳細(xì)介紹了Python如何實(shí)現(xiàn)簡(jiǎn)單的彈球小游戲,文中講解非常細(xì)致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2022-11-11
  • Python?web框架實(shí)現(xiàn)增加BasicAuth認(rèn)證詳解

    Python?web框架實(shí)現(xiàn)增加BasicAuth認(rèn)證詳解

    這篇文章主要為大家詳細(xì)介紹了Python如何在web框架中實(shí)現(xiàn)增加BasicAuth認(rèn)證,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起了解一下
    2023-05-05

最新評(píng)論