国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > Python > 正文

python爬蟲(chóng)框架scrapy實(shí)戰(zhàn)之爬取京東商城進(jìn)階篇

2020-02-23 04:37:20
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

前言

之前的一篇文章已經(jīng)講過(guò)怎樣獲取鏈接,怎樣獲得參數(shù)了,詳情請(qǐng)看python爬取京東商城普通篇,本文將詳細(xì)介紹利用python爬蟲(chóng)框架scrapy如何爬取京東商城,下面話(huà)不多說(shuō)了,來(lái)看看詳細(xì)的介紹吧。

代碼詳解

1、首先應(yīng)該構(gòu)造請(qǐng)求,這里使用scrapy.Request,這個(gè)方法默認(rèn)調(diào)用的是start_urls構(gòu)造請(qǐng)求,如果要改變默認(rèn)的請(qǐng)求,那么必須重載該方法,這個(gè)方法的返回值必須是一個(gè)可迭代的對(duì)象,一般是用yield返回。

代碼如下:

def start_requests(self): for i in range(1,101): page=i*2-1 #這里是構(gòu)造請(qǐng)求url的page,表示奇數(shù) url=self.start_url+str(page) yield scrapy.Request(url,meta={'search_page':page+1},callback=self.parse_url) #這里使用meta想回調(diào)函數(shù)傳入數(shù)據(jù),回調(diào)函數(shù)使用response.meta['search-page']接受數(shù)據(jù)

下面就是解析網(wǎng)頁(yè)了,從上面看出這里的解析回調(diào)函數(shù)是parse_url,因此在此函數(shù)中解析網(wǎng)頁(yè)。這里還是和上面說(shuō)的一樣,這個(gè)url得到的僅僅是前一半的信息,如果想要得到后一半的信息還有再次請(qǐng)求,這里還有注意的就是一個(gè)技巧:一般先解析出一個(gè)數(shù)據(jù)的數(shù)組,不急著取出第一個(gè)數(shù),先要用if語(yǔ)句判斷,因?yàn)槿绻玫降氖荹],那么直接取出[0]是會(huì)報(bào)錯(cuò)的,這只是一個(gè)避免報(bào)錯(cuò)的方法吧。

代碼如下:

def parse_url(self,response): if response.status==200: #判斷是否請(qǐng)求成功 # print response.url pids = set() #這個(gè)集合用于過(guò)濾和保存得到的id,用于作為后面的ajax請(qǐng)求的url構(gòu)成 try: all_goods = response.xpath("http://div[@id='J_goodsList']/ul/li") #首先得到所有衣服的整個(gè)框架,然后從中抽取每一個(gè)框架 for goods in all_goods: #從中解析每一個(gè) # scrapy.shell.inspect_response(response,self) #這是一個(gè)調(diào)試的方法,這里會(huì)直接打開(kāi)調(diào)試模式 items = JdSpiderItem() #定義要抓取的數(shù)據(jù) img_url_src = goods.xpath("div/div[1]/a/img/@src").extract() # 如果不存在就是一個(gè)空數(shù)組[],因此不能在這里取[0] img_url_delay = goods.xpath(  "div/div[1]/a/img/@data-lazy-img").extract() # 這個(gè)是沒(méi)有加載出來(lái)的圖片,這里不能寫(xiě)上數(shù)組取第一個(gè)[0] price = goods.xpath("div/div[3]/strong/i/text()").extract() #價(jià)格 cloths_name = goods.xpath("div/div[4]/a/em/text()").extract() shop_id = goods.xpath("div/div[7]/@ data-shopid").extract() cloths_url = goods.xpath("div/div[1]/a/@href").extract() person_number = goods.xpath("div/div[5]/strong/a/text()").extract() pid = goods.xpath("@data-pid").extract() # product_id=goods.xpath("@data-sku").extract() if pid:  pids.add(pid[0]) if img_url_src: # 如果img_url_src存在  print img_url_src[0]  items['img_url'] = img_url_src[0] if img_url_delay: # 如果到了沒(méi)有加載完成的圖片,就取這個(gè)url  print img_url_delay[0]  items['img_url'] = img_url_delay[0] # 這里如果數(shù)組不是空的,就能寫(xiě)了 if price:  items['price'] = price[0] if cloths_name:  items['cloths_name'] = cloths_name[0] if shop_id:  items['shop_id'] = shop_id[0]  shop_url = "https://mall.jd.com/index-" + str(shop_id[0]) + ".html"  items['shop_url'] = shop_url if cloths_url:  items['cloths_url'] = cloths_url[0] if person_number:  items['person_number'] = person_number[0] # if product_id: # print "************************************csdjkvjfskvnk***********************" # print self.comments_url.format(str(product_id[0]),str(self.count)) # yield scrapy.Request(url=self.comments_url.format(str(product_id[0]),str(self.count)),callback=self.comments) #yield scrapy.Request寫(xiě)在這里就是每解析一個(gè)鍵褲子就會(huì)調(diào)用回調(diào)函數(shù)一次 yield items except Exception: print "********************************************ERROR**********************************************************************" yield scrapy.Request(url=self.search_url.format(str(response.meta['search_page']),",".join(pids)),callback=self.next_half_parse) #再次請(qǐng)求,這里是請(qǐng)求ajax加載的數(shù)據(jù),必須放在這里,因?yàn)橹挥械鹊降玫剿械膒id才能構(gòu)成這個(gè)請(qǐng)求,回調(diào)函數(shù)用于下面的解析            
發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 城口县| 滁州市| 临泽县| 永善县| 呼伦贝尔市| 凤翔县| 临武县| 确山县| 社旗县| 巴彦淖尔市| 珲春市| 都江堰市| 华亭县| 昭觉县| 桦川县| 大邑县| 靖安县| 南宁市| 莱西市| 旬阳县| 新绛县| 福州市| 灵寿县| 如皋市| 和硕县| 九江县| 新巴尔虎右旗| 墨玉县| 瑞金市| 莲花县| 池州市| 武隆县| 陆川县| 望谟县| 瓦房店市| 尼勒克县| 巩义市| 鸡西市| 贵德县| 江口县| 望都县|