Python爬蟲系列-Xpath自如和bs4鏈家

爬完魔方之后两残,再接再厲爬取自如和鏈家,然后...不出意外的又失敗了把跨!在向右老師和羽恒大神的拯救下人弓,終于把我從坑里挖了出來。雖然錯(cuò)的也還有點(diǎn)稀里糊涂的着逐,但前事不忘崔赌,后事之師。下面把遇到的坑簡單說一下耸别。
<h4>xpath找自如</h4>
首先找到自如友家杭州站的地址健芭,http://hz.ziroom.com/z/nl/z2.html
我覺得我也就是這個(gè)第一級的網(wǎng)址能找對了...
然后觀察網(wǎng)址,找需要的標(biāo)題太雨,地址和價(jià)格

圖片.png
下面是我寫的程序
...
infos=selector.xpath('div//li[@class="clearfix"]/div/')
list_dict=[]
for info in infos:
    item={} 
    name=info.xpath('div/h3/a/text()')[0] 
    address=info.xpath('div/h4/a/text()')[0]        
    price=info.xpath('p/[@class="price"]/text()')[0]

當(dāng)時(shí)我的邏輯是吟榴,在chrome用小箭頭找到每個(gè)房源的地址,得到class=clearfix這一級囊扳,然后向下吩翻。然后標(biāo)題在txt下的“h3”處,地址在“h4”處锥咸,價(jià)格在另一個(gè)標(biāo)簽price處狭瞎。然后就試著寫下來,結(jié)果是運(yùn)行不出來....

大神的診斷:一個(gè)是需要請求頭偽裝搏予,另外就是地址還要取高一級熊锭,點(diǎn)選到所有的房源。
還有定位還不夠準(zhǔn)確,div要定到第二個(gè)碗殷,所以是div[2]精绎。價(jià)格這里,因?yàn)槎壗Y(jié)構(gòu)Infos已經(jīng)定位到價(jià)格锌妻,所以不要再寫class=price這些了代乃,直接用p[1]定位。

#coding:utf-8
import requests
from lxml import etree
import random

url='http://sz.ziroom.com/z/nl/z2.html'
def getReqHeaders():
    """
    功能:隨機(jī)獲取HTTP_User_Agent
    """
    user_agents=[
    "Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.103 Safari/537.36"]
    user_agent = random.choice(user_agents)
    req_headers={
    'User-Agent':user_agent
    }
    return req_headers

html=requests.get(url,headers=getReqHeaders()).content
#print(html)
selector=etree.HTML(html)
infos=selector.xpath('//*[@id="houseList"]/li')
#print infos

list_dict=[]
for info in infos:
    item={}
    name=info.xpath('div[2]/h3/a/text()')[0]
    address=info.xpath('div[2]/h4/a/text()')[0]
    price=info.xpath('div[3]/p[1]/text()')[0]
    print name, '      ',address, '      ',price
    #item['name']=name
    #item['address']=address
    #item['price']=price
    #list_dict.append(item)
#print list_dict

在地址向上一欄這里我糾結(jié)了很久仿粹,因?yàn)榕滥Х降臅r(shí)候搁吓,程工教路,取值就是從clearfix這里取的吭历,用小箭頭點(diǎn)選單個(gè)公寓列表得到堕仔。而自如這里改為id這一級,從所有公寓列表選取晌区。似乎邏輯不同呢摩骨,我要再好好想想...

html=requests.get(url).content
selector=etree.HTML(html)
infos=selector.xpath('//div[@class="orgs-room clearfix"]/div[2]')

for info in infos:
    shop_name=info.xpath('p[@class="room-hd"]/a/text()')[0]
    address=info.xpath('p[@class="address"]/text()')[0]
    room_money=info.xpath('p[@class="room-money"]/strong/text()')[0].lstrip('均價(jià):¥').rstrip('/月')
    print shop_name,address,room_money

<h4>BeautifulSoup爬鏈家</h4>
試著用bs4爬鏈家,并且加上頁數(shù)的循環(huán)朗若。
其實(shí)鏈家的結(jié)構(gòu)是公認(rèn)很清晰的仿吞,用采集器爬的時(shí)候,什么跳轉(zhuǎn)都不用捡偏。但是自己一寫代碼,就馬上暴露學(xué)習(xí)的不足了...

圖片.png

自己寫的代碼峡迷,有兩個(gè)問題银伟,一個(gè)是爬出來的都是單一房源,另一個(gè)是列表绘搞,無法用text找到彤避。 比如寫成"address=lj.find_all('div',attrs={'class':'address'}).text"就會報(bào)錯(cuò)。

(前略)
url='http://gz.lianjia.com/ershoufang/'
for i in range(1,2):
    i=str(i)
    a=(url+'pg'+i+'/')
    html=requests.get(url=a).text

lista=[]
lj=BeautifulSoup(html, "lxml")
infos=lj.find_all('div',attrs={'class':'info clear'})
for info in infos:
    item={}
    title=lj.find_all('div',attrs={'class':'title'})
    print type(title)
    address=lj.find_all('div',attrs={'class':'address'})
    price=lj.find_all('div',attrs={'class':'totalPrice'})
 (以下略)

下面是向右老師改的代碼:

import requests
from bs4 import BeautifulSoup
url='http://bj.lianjia.com/ershoufang/'
for i in range(1,3):
    i=str(i)
    a=(url+'pg'+i+'/')
    print a      
    html=requests.get(url=a).content

    lj=BeautifulSoup(html, "html.parser")
    for info in lj.find_all('div', attrs={'class': 'info clear'}):
        title = info.select('div.title > a')[0].get_text()
        print title
        price = info.select('div.priceInfo > div > span')[0].text
        print price
        loc = info.select('div.flood > div')[0].text
        print loc

原因是夯辖,一個(gè)是沒有把爬頁數(shù)和下面的每頁信息形成嵌套關(guān)系琉预,所以爬出來的結(jié)果都是一樣的;第二個(gè)還是網(wǎng)頁結(jié)構(gòu)沒把握好蒿褂,"class:info clear"這個(gè)二級結(jié)構(gòu)倒是找到了圆米,但是向右老師建議下面應(yīng)該用select,find找到的是一類標(biāo)簽啄栓,用來定位比較復(fù)雜娄帖。select的好處,就是可以一層一層的找到標(biāo)簽昙楚。
比如總價(jià)'div.priceInfo > div > span'這里近速,也可以寫成'div.priceinfo > div.totalPrice > span',span沒有屬性。
這樣就比attr要清楚很多削葱。

這個(gè)周末總算把兩個(gè)網(wǎng)站結(jié)構(gòu)又弄清楚了(雖然80%都是別人的功勞=毖恰)。另外看了天善智能邱祐瑋的爬蟲視頻析砸∥糇郑看視頻的時(shí)候覺得好簡單啊,自己做的時(shí)候怎么就那么復(fù)雜干厚!
第二級結(jié)構(gòu)該取哪一級李滴,還要好好弄明白。
第三級結(jié)構(gòu)的定位蛮瞄,每次的排列組合所坯,搞得我都沒信心了,還是人品+技術(shù)問題挂捅,要練習(xí)再練習(xí)芹助!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市闲先,隨后出現(xiàn)的幾起案子状土,更是在濱河造成了極大的恐慌,老刑警劉巖伺糠,帶你破解...
    沈念sama閱讀 218,525評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蒙谓,死亡現(xiàn)場離奇詭異,居然都是意外死亡训桶,警方通過查閱死者的電腦和手機(jī)累驮,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,203評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來舵揭,“玉大人谤专,你說我怎么就攤上這事∥缟” “怎么了置侍?”我有些...
    開封第一講書人閱讀 164,862評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長拦焚。 經(jīng)常有香客問我蜡坊,道長,這世上最難降的妖魔是什么赎败? 我笑而不...
    開封第一講書人閱讀 58,728評論 1 294
  • 正文 為了忘掉前任算色,我火速辦了婚禮,結(jié)果婚禮上螟够,老公的妹妹穿的比我還像新娘灾梦。我一直安慰自己峡钓,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,743評論 6 392
  • 文/花漫 我一把揭開白布若河。 她就那樣靜靜地躺著能岩,像睡著了一般。 火紅的嫁衣襯著肌膚如雪萧福。 梳的紋絲不亂的頭發(fā)上拉鹃,一...
    開封第一講書人閱讀 51,590評論 1 305
  • 那天,我揣著相機(jī)與錄音鲫忍,去河邊找鬼膏燕。 笑死,一個(gè)胖子當(dāng)著我的面吹牛悟民,可吹牛的內(nèi)容都是我干的坝辫。 我是一名探鬼主播,決...
    沈念sama閱讀 40,330評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼射亏,長吁一口氣:“原來是場噩夢啊……” “哼近忙!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起智润,我...
    開封第一講書人閱讀 39,244評論 0 276
  • 序言:老撾萬榮一對情侶失蹤及舍,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后窟绷,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體锯玛,經(jīng)...
    沈念sama閱讀 45,693評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,885評論 3 336
  • 正文 我和宋清朗相戀三年兼蜈,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了更振。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,001評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡饭尝,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出献宫,到底是詐尸還是另有隱情钥平,我是刑警寧澤,帶...
    沈念sama閱讀 35,723評論 5 346
  • 正文 年R本政府宣布姊途,位于F島的核電站涉瘾,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏捷兰。R本人自食惡果不足惜立叛,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,343評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望贡茅。 院中可真熱鬧秘蛇,春花似錦其做、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,919評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至艘策,卻和暖如春蹈胡,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背朋蔫。 一陣腳步聲響...
    開封第一講書人閱讀 33,042評論 1 270
  • 我被黑心中介騙來泰國打工罚渐, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人驯妄。 一個(gè)月前我還...
    沈念sama閱讀 48,191評論 3 370
  • 正文 我出身青樓荷并,卻偏偏與公主長得像,于是被迫代替她去往敵國和親富玷。 傳聞我的和親對象是個(gè)殘疾皇子璧坟,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,955評論 2 355

推薦閱讀更多精彩內(nèi)容