【Python爬蟲】手機號網(wǎng)段爬蟲

整體爬蟲邏輯:

1.獲取省份和城市的定位啸盏,然后定位出各個城市和相對應的url
2.獲取到 130 xx號段 (共317個)中的xxx個



3.獲取最終的號段號碼

先貼上源碼

#抓取省份及城市
import requests
from lxml import etree
url='http://www.51hao.cc/'
req=requests.get(url)
req.encoding='gb2312'
html=req.text
select=etree.HTML(html)
infos=select.xpath('//div[@class="fkce"]/div[@class="fkt"][position()>1]')
#print(len(infos))  #核對下省的數(shù)量是否一致
for info in infos:
    #定位省的地址
    province=info.xpath('div[@class="fkbj"]/p/a/text()')[0]
    #print(province)
    #定位城市
    citys=info.xpath('div[@class="fklk"]/p/a/text()')
    #print(citys)
    #城市的url
    city_urls = info.xpath('div[@class="fklk"]/p/a/@href')
    #print(province,citys,city_urls)
    city_infos = zip(citys, city_urls)  #zip函數(shù)接受任意多個(包括0個和1個)序列作為參數(shù)兜蠕,返回一個tuple列表系草。
    #print(city_infos)
    for city_info in city_infos:
        city=city_info[0]
        #print(city)
        city_url=city_info[1]
        #print(province,city,city_url)


        url2 = 'http://www.51hao.cc/city/beijing/beijing.php'
        req2 = requests.get(url2)
        req2.encoding = 'gb2312'
        html2 = req2.text
        selector2 = etree.HTML(html2)
        infos = selector2.xpath('//div[@class="all"]//div[@class="num_bg"]')
        num = len(infos)
        # print(num)   #打印出共有多少個
        for i in range(num):
            first_3 = selector2.xpath('//div[@class="all"]/div[%s]/div[1]/span[@class="nums"]/text()' % str(i + 2))[
                0]  # 號碼段前三位
            # print(first_3)
            types = selector2.xpath('//div[@class="all"]/div[%s]/div[1]/text()' % str(i + 2))[0]  # xx號段 (共xxx個)
            # print(types)
            mobiles = selector2.xpath('//div[@class="all"]/ul[%s]/li/a/text()' % str(i + 1))  # 號碼段內的號碼
            # print(mobiles)
            type1 = types.split(" ")[0]  # 獲取xx號段 (共xxx個)中xx號段
            # print(type1)
            total = types.split(' ')[1].replace('(共', '').replace('個)', '')  # 獲取(共xxx個)中的xxx
            # print(total)
            # print(i+2,first_3,type1,total,mobiles)
            for mobile in mobiles:
                #print(i + 2, first_3, type1, total, mobile)
                print(province, city, first_3, type1, total, mobile)
爬蟲結果

關于定位的問題:

 1.   infos=select.xpath('//div[@class="fkce"]/div[@class="fkt"][position()>1]')  

第一個div[class="fkce"]下可以找到省份和城市锋拖,可是div[@class="fkce"]下第一個div[@class="fkt"]下的第一個為各省市號段的那一列,要過濾掉第一個div侨嘀,這里用到position()過濾第一div內的內容燕差。


2.   city_infos = zip(citys, city_urls) #把city是,和city_urls返回一個元祖秽褒,再去取里面的值


zip函數(shù)接受任意多個(包括0個和1個)序列作為參數(shù)册赛,返回一個tuple列表。只能在循環(huán)中打印出來震嫉。在循環(huán)中元祖中選出城市與相對應的url打印出來

城市的獲取

在循環(huán)中元祖中選出城市與相對應的url打印出來

3. infos=selector.xpath('//div[@class="all"]//div[@class="num_bg"]') #在這個范圍內找到     獲取到 130 xx號段 (共317個)中的xxx個
WX20170904-170305@2x.png
4.   first_3 = selector.xpath('//div[@class="all"]/div[%s]/div[1]/span[@class="nums"]/text()'%str(i+2))[0]    #號碼段前三位

用到了【 】方法


div[%s] %str(i+2))過濾第一個


5.    types = selector.xpath('//div[@class="all"]/div[%s]/div[1]/text()' % str(i + 2))[0] #xx號段 (共xxx個)
      mobiles = selector.xpath('//div[@class="all"]/ul[%s]/li/a/text()' % str(i + 1)) #號碼段內的號碼
6.   type1=types.split(" ")[0] #獲取xx號段 (共xxx個)中xx號段
     total = types.split(' ')[1].replace('(共', '').replace('個)', '')  #獲取(共xxx個)中的xxx

最后把獲取的連接到一起打印出來

 for mobile in mobiles:
        print(province, city, first_3, type1, total, mobile)
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末森瘪,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子票堵,更是在濱河造成了極大的恐慌扼睬,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,496評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件悴势,死亡現(xiàn)場離奇詭異窗宇,居然都是意外死亡,警方通過查閱死者的電腦和手機特纤,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,407評論 3 392
  • 文/潘曉璐 我一進店門军俊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人捧存,你說我怎么就攤上這事粪躬。” “怎么了昔穴?”我有些...
    開封第一講書人閱讀 162,632評論 0 353
  • 文/不壞的土叔 我叫張陵镰官,是天一觀的道長。 經常有香客問我吗货,道長泳唠,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,180評論 1 292
  • 正文 為了忘掉前任宙搬,我火速辦了婚禮笨腥,結果婚禮上拓哺,老公的妹妹穿的比我還像新娘。我一直安慰自己脖母,他們只是感情好士鸥,可當我...
    茶點故事閱讀 67,198評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著镶奉,像睡著了一般。 火紅的嫁衣襯著肌膚如雪崭放。 梳的紋絲不亂的頭發(fā)上哨苛,一...
    開封第一講書人閱讀 51,165評論 1 299
  • 那天,我揣著相機與錄音币砂,去河邊找鬼建峭。 笑死,一個胖子當著我的面吹牛决摧,可吹牛的內容都是我干的亿蒸。 我是一名探鬼主播,決...
    沈念sama閱讀 40,052評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼掌桩,長吁一口氣:“原來是場噩夢啊……” “哼边锁!你這毒婦竟也來了?” 一聲冷哼從身側響起波岛,我...
    開封第一講書人閱讀 38,910評論 0 274
  • 序言:老撾萬榮一對情侶失蹤茅坛,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后则拷,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體贡蓖,經...
    沈念sama閱讀 45,324評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,542評論 2 332
  • 正文 我和宋清朗相戀三年煌茬,在試婚紗的時候發(fā)現(xiàn)自己被綠了斥铺。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,711評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡坛善,死狀恐怖晾蜘,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情眠屎,我是刑警寧澤笙纤,帶...
    沈念sama閱讀 35,424評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站组力,受9級特大地震影響省容,放射性物質發(fā)生泄漏。R本人自食惡果不足惜燎字,卻給世界環(huán)境...
    茶點故事閱讀 41,017評論 3 326
  • 文/蒙蒙 一腥椒、第九天 我趴在偏房一處隱蔽的房頂上張望阿宅。 院中可真熱鬧,春花似錦笼蛛、人聲如沸洒放。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,668評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽往湿。三九已至,卻和暖如春惋戏,著一層夾襖步出監(jiān)牢的瞬間领追,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,823評論 1 269
  • 我被黑心中介騙來泰國打工响逢, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留绒窑,地道東北人。 一個月前我還...
    沈念sama閱讀 47,722評論 2 368
  • 正文 我出身青樓舔亭,卻偏偏與公主長得像些膨,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子钦铺,可洞房花燭夜當晚...
    茶點故事閱讀 44,611評論 2 353

推薦閱讀更多精彩內容

  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統(tǒng)中一些常見模式的工具(例如配置管理订雾,服務發(fā)現(xiàn),斷路器矛洞,智...
    卡卡羅2017閱讀 134,651評論 18 139
  • 1. Java基礎部分 基礎部分的順序:基本語法葬燎,類相關的語法,內部類的語法缚甩,繼承相關的語法谱净,異常的語法,線程的語...
    子非魚_t_閱讀 31,623評論 18 399
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,077評論 25 707
  • “白青青擅威,你這個月的房租要等到什么時候才肯交昂咎健?我告訴你郊丛,現(xiàn)在來找我租房子的人多著呢李请,還有人愿意出兩倍的租金呢。你...
    命起漣漪o0閱讀 206評論 0 0
  • 朝陽區(qū)群眾又發(fā)威了。這次雖沒有那個明星進局子揍瑟,倒是實則把人嚇了一跳白翻。 近日,北京CBD商業(yè)街一場別開生面的武術團體...
    娛樂當然閱讀 615評論 0 0