首页 » 网站建设 » php观光比价源码技巧_若何编写python爬虫以及在张大年夜妈比价项目中的应用

php观光比价源码技巧_若何编写python爬虫以及在张大年夜妈比价项目中的应用

访客 2024-12-15 0

扫一扫用手机浏览

文章目录 [+]

项目背景:电商平台浩瀚,监测每个电商平台逐日价格涌现历史新低的商品,同一型号商品在不同电商平台的价格并且在同一张图标中绘制出来,方便筛须要的商品

项目名称:Hi张大妈比价(hizdm.com)

php观光比价源码技巧_若何编写python爬虫以及在张大年夜妈比价项目中的应用

方案履行:如果要进行价格比对,当然少不了对数据的抓取,由于本人比较善于php但通过百度(如果能用狗哥,谁还用它啊,虽说有vpn彷佛被360网络了常常断)得知python抓取会更好一些,于是就选择了python,之前没有用过python,于是在网上学了学python。

php观光比价源码技巧_若何编写python爬虫以及在张大年夜妈比价项目中的应用
(图片来自网络侵删)

由于是比价固得先有思路,由于有些商品没法标准化,还好要买的电器还是能找到标准化的规则(爬虫爬取每个商品的解释找到产品型号,没错我进行数据标准化的规则便是按着商品型号来的)

首先选一些种子选手,京东、苏宁、国美,谁让你们在家电方面是龙头呢,O(∩_∩)O哈哈~,由于是新手我一次就抓取了所须要的产品缩略图、产品链接、产品参数、产品名称以及产品型号进行独立存取,这样文件在往后再进行比对筛选唯一(对型号进行字符串规则化,更换中文括号横线等等然后在strtolow,这样比对起来成功匹配率在98%),然后在入库(网站根本方案就不详解了,如感兴趣可联系我)。

以京东为例爬虫如下:

! /usr/bin/python

#utf-8

import re

import os

import sys

import time

import urllib2

import cookielib

from bs4 import BeautifulSoup

reload(sys)

sys.setdefaultencoding('utf-8')

class jdSpider:

def __init__(self, url, header, header2, brand):

self.url = url

self.header = header

self.header2 = header2

self.brand = brand

def crawl(self):

req = urllib2.Request(self.url, headers = self.header)

con = urllib2.urlopen(req)

html = con.read()

con.close()

soup = BeautifulSoup(html)

one = soup.find('ul', {'class' : 'gl-warp'})

two = one.find_all('li', {'class' : 'gl-item'})

i = 0

c = ''

img = ''

base = 'http:'

for three in two:

i = i + 1

print i

if i > 0:

img = base + str(three.find('img').get('data-lazy-img'))

four = three.find('div', {'class' : 'p-name'})

product_link = base + str(four.find('a').get('href'))

product_name = four.find('em').get_text()

req2 = urllib2.Request(product_link, headers = self.header2)

con2 = urllib2.urlopen(req2)

html2 = con2.read()

con2.close()

soup2 = BeautifulSoup(html2)

five = soup2.find('table', {'class' : 'Ptable'})

if five:

six = five.find_all('td')

j = 1

tag = ''

brand = ''

param = ''

for seven in six:

if j == 2:

brand = seven.get_text().strip()

if j == 4:

tag = seven.get_text().strip()

if j % 2 == 1:

param = param + seven.get_text().strip() + '||'

else:

param = param + seven.get_text().strip() + '|||'

j = j + 1

c = 'jd^^^' + brand + '^^^' + tag + '^^^' + product_name + '^^^' + product_link + '^^^' + img + '^^^' + param + '\n'

print c

if __name__ == '__main__':

'

header = {'Host': 'list.jd.com',

'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; rv:26.0) Gecko/20100101 Firefox/26.0',

'Accept': 'textml,application/xhtml+xml,application/xml;q=0.9,/;q=0.8',

'Accept-Encoding': 'deflate',

'Connection': 'keep-alive'}

header2 = {'Host': 'item.jd.com',

'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; rv:26.0) Gecko/20100101 Firefox/26.0',

'Accept': 'textml,application/xhtml+xml,application/xml;q=0.9,/;q=0.8',

'Accept-Encoding': 'deflate',

'Connection': 'keep-alive'}

brand = raw_input(\"大众Product: \公众)

url = raw_input(\"大众Url: \公众)

spider = jdSpider(url, header, header2, brand)

spider.crawl()

以上代码可供大家研究版权归属Hi张大妈比价,由于python是速成,请大家轻喷,当然也希望大家支持Hi张大妈(hizdm.com)!

标签:

相关文章

thinkphp高并发技巧_高并发我把握不住啊

我关注的大佬更新了,在干货文章的下面有这么一小条:我承认我有赌的身分,点进去一看,果真是广告。说真的,内容看起来还是很有吸引力的,...

网站建设 2024-12-17 阅读0 评论0

云浪大数据,驱动未来商业的智能引擎

随着信息技术的飞速发展,大数据已经渗透到我们生活的方方面面,成为推动社会进步的重要力量。云浪大数据,作为我国大数据领域的一匹黑马,...

网站建设 2024-12-17 阅读0 评论0

云盘,新时代存储与共享的智慧选择

随着互联网技术的飞速发展,大数据、云计算等新兴概念逐渐融入人们的生活。在这样的背景下,云盘作为一种新型的存储与共享方式,受到了广泛...

网站建设 2024-12-17 阅读0 评论0

云视通,开启智慧安防新时代的领航者

随着科技的飞速发展,智慧安防逐渐成为社会安全的重要组成部分。云视通作为安防领域的领航者,以其先进的技术、卓越的品质和优质的服务,为...

网站建设 2024-12-17 阅读0 评论0