python实战案例——采集二手车数据并分析其价值

前言

嗨喽,大家好呀~这里是爱看美女的茜茜呐

又到了学Python时刻~


环境使用:

  • Python 3.8

  • Pycharm

    • 专业版是付费的 <激活码可以免费用>

    • 社区版是免费的


模块使用:

第三方模块 需要安装的

  • requests >>> pip install requests

  • parsel >>> pip install parsel

  • csv


安装python第三方模块:

  1. win + R 输入 cmd 点击确定, 输入安装命令 pip install 模块名 (pip install requests) 回车

  2. 在pycharm中点击Terminal(终端) 输入安装命令


爬虫基本流程:

一. 数据来源分析
  1. 明确需求:

    • 明确采集网站是什么?

    • 明确采集数据是什么?

      车辆基本信息

  2. 分析 车辆基本信息数据, 具体是请求那个网址可以得到

    通过开发者工具, 进行抓包分析:

    • 打开开发者工具: F12 / 鼠标右键点击检查选择network

    • 刷新网页: 让本网页数据内容重新加载一遍 <方便分析数据出处>

    • 搜索数据来源: 复制你想要的内容, 进行搜索即可

      车辆信息数据

二. 代码实现步骤
  1. 发送请求, 模拟浏览器对于url地址发送请求

  2. 获取数据, 获取服务器返回响应数据

    开发者工具: response <网页源代码>

  3. 解析数据, 提取我们想要的数据内容

    • 车辆信息
  4. 保存数据, 把车辆信息保存csv表格里面


代码展示

PS:本篇完整源码如有需要的小伙伴可以加下方的群去找管理员免费领取

采集数据

导入模块

# 导入数据请求模块 --> 第三方模块 需要安装 pip install requests
import requests
# 导入数据解析模块 --> 第三方模块 需要安装 pip install parsel
import parsel
# 导入csv模块 --> 内置模块 不需要安装
import csv

创建文件

f = open('data.csv', mode='a', encoding='utf-8', newline='')
csv_writer = csv.DictWriter(f, fieldnames=[
    '标题',
    '年份',
    '里程',
    '城市',
    '价格',
    '标签',
    '是否保修',
    '详情页',
])

写入表头

csv_writer.writeheader()

“”"

  1. 发送请求, 模拟浏览器对于url地址发送请求
    • 安装模块: win + R 输入cmd
      输入安装命令: pip install requests

    • 导入模块是灰色, 不是报错, 而是导入模块没有使用

    • 伪装模拟 headers 请求头

      1. 字典数据类型, 要构建完整键值对 <引号位置一定要加对>
      2. 可以直接复制
    • <Response [200]> 响应对象
      200 状态码 表示请求成功

    • 批量替换

      1. 选择替换内容
      2. ctrl + R 输入正则命令即可
        :.*
        ,

“”"

for page in range(1, 51):
    print(f'======================正在采集第{
   page}页的数据内容======================')

确定请求链接

    # 伪装模拟
    headers = {
   
        # User-Agent 用户代理 表示浏览器基本身份信息
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/101.0.0.0 Safari/537.36'
    }
    # 发送请求
    response = requests.get(url=url, headers=headers)
    print(response)

“”"

  1. 获取数据, 获取服务器返回响应数据
    开发者工具: response <网页源代码>
    response.text 获取响应文本数据 <网页源代码>
    html字符串数据 --> re正则

  2. 解析数据, 提取我们想要的数据内容
    - 车辆信息

    css选择器: 根据标签属性提取内容
    选择器对象

“”"

    # 把获取下来 response.text 转成 可解析对象
    selector = parsel.Selector(response.text)
    
  • 6
    点赞
  • 73
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值