百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

如何编写python爬虫?以及在张大妈比价项目中的应用!

moboyou 2025-07-02 05:45 13 浏览

最近打算买一些家电,但是电商平台众多,于是我想看看每天到底有多少商品进行降价了,同一款商品在不同平台中的价格又是多少?于是我从0开始翻阅了一些python资料,写了几个python小爬虫。

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

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

方案实施:如果要进行价格比对,当然少不了对数据的抓取,由于本人比较擅长php但通过百度(如果能用狗哥,谁还用它啊,虽说有vpn好像被360收集了经常断)得知python抓取会更好一些,于是就选择了python,之前没有用过python,于是在网上学了学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)!

相关推荐

高效有趣学Excel:从入门到精通的全面教程分享

在当今这个数据驱动的时代,掌握Excel不仅是提升工作效率的利器,更是职场竞争中的一项重要技能。今天,我非常高兴地与大家分享一套全面的Excel学习教程——《高效有趣学Excel:轻松入门到精通》,这...

Excel新函数重磅来袭!告别复杂公式,效率提升200%!

“透视表终于不用点来点去了?”昨晚刷到这条留言,顺手把新表扔进365,一行=GROUPBY(部门,产品,销售额,SUM)回车,三秒出汇总,刷新按钮直接失业。那一刻,办公室空调声都显得多余。有人还在录宏...

Excel 效率神器:LET 函数入门教程,让复杂公式变简单

您是否曾经编写过又长又复杂的Excel公式,然后没过几天自己都看不懂了?或者,同一个计算在公式里重复写了无数次,不仅容易出错,修改起来更是噩梦?Excel推出的LET函数就是来解决这些痛点...

Excel多对多查询函数新手教程:从案例到实操

一、为啥要学多对多查询?举个例子你就懂!假设你是公司HR,手里有张员工技能表(如下),现在需要快速找出:"张三"会哪些技能?"Excel"技能有哪些人掌握?员工姓名...

14、VBA代码+excel内置函数,实现高效数据处理(零基础入门)

1、学习VBA的主要目的是数据处理,VBA在数据处理上展现出强大的计算实力。它不仅完美继承EXCEl内置函数的功能,还能通过编程语法实现更灵活的应用。无论是基础的加减乘除,还是复杂的统计分析、逻辑判断...

word和excel零基础学习免费视频教程,赶紧收藏,作者将转付费课

亲爱的朋友们:大家好!本人是全国计算机等级考试二级MSoffice高级应用课程的在校授课老师。本人近段时间打算将wore/excel免费分享给所有有需要的朋友。知识本身无深浅,本人知识也有限,如果讲...

excel函数从入门到精通,5组13个函数,易学易懂易用

对于职场中经常使用Excel的小伙伴们,最希望掌握一些函数公式,毕竟给数据处理带来很多方便,可以提高我们的工作效率。今天分享几组函数公式,适合于初学者,也是职场中经常用到的,下次碰到可以直接套用了。0...

Excel效率神器:LET函数入门教程,让复杂公式变简单

写公式写到想砸电脑?教你用LET把Excel公式从“迷宫”变成“小剧本”,几步看懂又好改很多人都经历过这样的窘境:花了半小时写出一条看似厉害的Excel公式,几天后再看自己都懵了,或者同样...

完全免费的Excel教程大全,适合日常excel办公和技能提升

说明微软官方的excel文档,由于网站在国外,有时打开慢,而且应用层面介绍不够详细;这里介绍一个集齐了excel各种使用方法和说明的网站;网站名称:懒人Excel网站介绍可以看到有基础教程、快捷键、函...

Excel 新函数 LAMBDA 入门级教程_excel365新增函数

LAMBDA函数的出现是Excel历史上的一次革命性飞跃。它允许用户自定义函数,而无需学习VBA等编程语言。这意味着你可以将复杂的、重复的计算逻辑封装成一个简单的、可复用的自定义函数,极大地...

Excel新函数LAMBDA入门级教程_excel新建函数

把复杂公式“变成函数”后,我在Excel上的重复工作少了一半——你也能做到我一直有一个习惯:遇到每天要重复写的复杂公式,就想把它封装起来,像调用内置函数那样去用。说实话,过去没有LAMBDA,这个想法...

Excel DROP 函数全方位教程:从基础入门到高级动态应用

上一篇我们学习了ExcelTAKE函数,今天我们来学习一下和TAKE函数相对应的DROP函数,它是Microsoft365和Excel2021中引入的一个动态数组函数。它的核心功能是从一...

学习Excel公式函数还有官方提供的教程,还是免费的!赶紧试试

首先声明,这不是广告,纯干货分享!除了学习Excel的基本操作之外,很多人都是冲着公式和函数才去找教程买教材的,这个结论应该不会有什么毛病。因为,Excel的公式函数真的很强大!现在的Excel教程可...

什么是保险员常说的“IRR”?让我们一次说明白!

买保险的时候,你是不是常听到销售抛出一些术语,比如“IRR很高哦,收益不错!”?听着挺专业,但“IRR”到底啥意思?想问又不好意思问,别急,它其实是个很简单的概念,咱们今天一次把它说明白。1,IRR...

理财型保险如何选择缴费期?_理财型保险计算方式

选择理财型保险(通常指年金险、增额终身寿险等)的缴费期,并非简单地看哪个年限短或长,而是需要结合自己的财务状况、理财目标和产品特性来综合决定。下面我将为大家详细解析不同缴费期的特点、适用人群和选择策略...