python爬虫之四 —— selenium和京东商品

本文介绍了如何结合selenium和Python来抓取京东商品列表数据。通过打开京东首页,搜索关键字,自动滚动页面,解析源码并存储数据,实现了动态网页的爬取。尽管selenium速度较慢,但其能有效应对动态内容,使得处理更复杂的爬虫任务成为可能。
摘要由CSDN通过智能技术生成

前言

如果说爬虫是模拟浏览器向服务器发送请求,获取数据,那么有了selenium之后,我们可以操控浏览器自动帮我们抓取数据。关于selenium在python中的使用,可以参考Selenium DocumentationSelenium with Python中文翻译文档

步骤

这次以京东为例,获取京东的商品列表数据。步骤如下

  1. 打开首页
  2. 搜索关键字,进入第一页
  3. 网页下拉
  4. 获取网页源码,解析网页
  5. 存储数据
  6. 翻页,重复3、4、5步

最终我们能拿到如下数据,虽然selenium有一个非常明显的缺点——速度太慢,但却能轻松帮我们搞定动态网页,python + selenium合理使用我们能做很多事情。
在这里插入图片描述

详细代码

from selenium import webdriver
from selenium.webdriver.common.keys import Keys
from selenium.webdriver.chrome.options import Options
from bs4 import BeautifulSoup as bs
import time
import json


class JD:
    def __init__(self):
        self.url = 'https://www.jd.com/'
        self.chrome_options = Options()
        self.chrome_options.add_argument('--headless')
        self.driver = webdriver.Chrome(self.chrome_options) 
#        self.driver.maximize_window()
    
    def search(self, keyword):
        element = self.driver.find_element_by_id('key'
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值