IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发工具 -> Python 爬虫 -> 正文阅读

[开发工具]Python 爬虫

Python爬虫教程(超详细)

下面以爬取亚马逊图书销售排行榜top100为例

话不多说,直接上代码(都可以直接使用)
1. 获取网页数据,存入excel文件

from urllib import request, error
import xlwt
from bs4 import BeautifulSoup
import re


class Spider:
    def __init__(self, baseUrl, itemInfs):
        self.dataList = []
        self.baseUrl = baseUrl
        self.itemInfs = itemInfs

    def getHtml(self, baseUrl):
        # 用户代理,注意修改User-Agent
        head = {
            "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64)"
        }

        req = request.Request(baseUrl, headers=head)
        html = ""
        try:
            response = request.urlopen(req)
            html = response.read().decode("utf-8")
        except error.URLError as e:
            if hasattr(e, "code"):
                print(e.code)
            if hasattr(e, "reason"):
                print(e.reason)
        return html
	
	#解析数据
    def parseData(self, it):
        data = []
        res = re.findall(eval(self.itemInfs["name"]), it)
        res = re.sub(r'\\n', '', str(res))
        res = re.sub(r' ', '', str(res))
        res = re.sub(r"\(.*?\)|\【.*?\】|\(.*?\)", "", str(res))
        data.append(eval(res))
        res = re.findall(eval(self.itemInfs["author"]), it)
        data.append((res))
        res = re.findall(eval(self.itemInfs["price"]), it)
        data.append((res))
        res = re.findall(eval(self.itemInfs["star"]), it)
        res = str.replace(str(res), ' ', '')
        data.append(eval(res))
        res = re.findall(eval(self.itemInfs["judgeNum"]), it)
        res = str.replace(str(res), ',', '')
        data.append(eval(res))

        return data

    def getData(self):
        # 获取网页源码,有两页,所以获取两次
        for i in range(2):
            html = self.getHtml(self.baseUrl+str(i+1))
            soup = BeautifulSoup(html, "html.parser")
            for item in soup.find_all('li', class_="zg-item-immersion"):
                data = self.parseData(str(item))
                self.dataList.append(data)
                print(data)

    def saveXls(self, filename):
        # 保存数据
        workbook = xlwt.Workbook(encoding="utf-8")
        worksheet = workbook.add_sheet('sheet1')
        keys = self.itemInfs.keys()
        for i, key in enumerate(keys):
            worksheet.write(0, i, key)
        for i, book in enumerate(self.dataList):
            for j, item in enumerate(book):
                worksheet.write(i + 1, j, item)
        workbook.save(filename)
        print("保存完成")


def main():
    # 要爬取的网页链接
    baseurl = "https://www.amazon.cn/gp/bestsellers/digital-text/ref=zg_bs_pg_2?ie=UTF8&pg="
	#正则表达式
    itemInfs = {
        "name": '''re.compile(r'<div aria-hidden="true" .{0,300}?>(.{0,300}?)</div>',re.S)''',
        "author": '''re.compile(r'<span class="a-size-small a-color-base">(.{0,100}?)</span>')''',
        "price": '''re.compile(r'<span class="p13n-sc-price">.(.*?)</span>')''',
        "star": '''re.compile(r'<span class="a-icon-alt">...(.*?).</span>')''',
        "judgeNum": '''re.compile(r'<a class="a-size-small a-link-normal" .{0,300}?>(.{0,100}?)</a>', re.S)''',
    }
	
	#要保存的文件名
    savexlsname = 'Amazon.xls'

    spider = Spider(baseurl, itemInfs)
    spider.getData()
    spider.saveXls(savexlsname)


if __name__ == "__main__":  # 当程序执行时
    main()
    print("爬取完毕!")

2. 将excel数据读取出来存入json文件

import pandas as pd

data = pd.read_excel(io='Amazon.xls')
df = pd.DataFrame(data)
df.to_json('Amazon1.json', orient="records")


#下面是用json模块方式
# import xlrd
#
#
# def read_xls(filename):
#     data = xlrd.open_workbook(filename)
#     table = data.sheets()[0]
#     rows = table.nrows
#     data = []   # 存放数据
#     for v in range(1, rows):
#         values = table.row_values(v)
#         data.append(
#             (
#                 {
#                 "name":str(values[0]),
#                 "author":str(values[1]),
#                 "price":str(values[2]),
#                 "star":str(values[3]),
#                 "judgeNum":str(values[4])
#                 }
#             )
#         )
#
#     return data
#
# if __name__ == '__main__':
#     d1 = read_xls("Amazon.xls")
#     d2 = str(d1).replace("\'", "\"")    # 单引号改为双引号
#     # d2 = "{\"Amazon\":" + d2 + "}"    # 加上大括号
#
#     jsFile = open("Amazon.json", "w+", encoding='utf-8')
#     jsFile.write(d2)
#     jsFile.close()

其实可以直接存json文件,但excel比较常用,就也演示一下

3. 数据分析

import pandas as pd
import numpy as np


# 读取json文件
# 方式一
# f = open('Amazon.json', 'r', encoding='utf-8')
# data = f.read()
# df = pd.read_json(data)

# 方式二
df = pd.read_json('Amazon1.json', orient='records')

# 缺失值填充
df[df.values == ''] = np.nan
df = df.fillna(method='bfill')    # 用下一个非缺失值填充该缺失值


# star 排名 60
df = df.sort_values(['star'], ascending=False)
print('*******star 排名 60*******')
print(df.iloc[0:60, 0:4])

# price 最贵
df = df.sort_values(['price'], ascending=False)
print('*******price 最贵*******')
print(df.iloc[0])


# 全部图书 star 值的均值和方差
# 修改数据类型(如果采用方式一读取json文件)
# df[['star']] = df[['star']].values.astype(float)
avg = df.iloc[:, 3].mean()
va = df.iloc[:, 3].var()

print('star 值的均值:{}'.format(avg))
print('star 值的方差:{}'.format(va))


# 相关性分析
# 修改数据类型(如果采用方式一读取json文件)
# df[['star']] = df[['star']].values.astype(float)
# df[['judgeNum']] = df[['judgeNum']].values.astype(float)

print(df.corr())

到这就结束啦,如有问题,大家评论区讨论。
在这里插入图片描述

  开发工具 最新文章
Postman接口测试之Mock快速入门
ASCII码空格替换查表_最全ASCII码对照表0-2
如何使用 ssh 建立 socks 代理
Typora配合PicGo阿里云图床配置
SoapUI、Jmeter、Postman三种接口测试工具的
github用相对路径显示图片_GitHub 中 readm
Windows编译g2o及其g2o viewer
解决jupyter notebook无法连接/ jupyter连接
Git恢复到之前版本
VScode常用快捷键
上一篇文章      下一篇文章      查看所有文章
加:2021-12-07 12:15:04  更:2021-12-07 12:15:33 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/23 22:24:32-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码