icer233 发表于 2024-9-17 15:43

【爬虫】爬取CCHO历年试卷及解析

目标网站:https://ccho.eduzhixin.com/archives/tag/csst
网站总共有3页:https://ccho.eduzhixin.com/archives/tag/csst/page/1
问题:个别详情页面结构不同,大部分的答案是pdf,个别的是图片或者没有,我直接跳过了,程序会提示哪个页面不行,需要手动处理
源码如下
# -*- coding:utf-8 -*-
import requests
from lxml import etree
import os
from multiprocessing.dummy import Pool

# 创建储存目录
if not os.path.exists('./ccho'):
    os.makedirs('./ccho')

url = 'https://ccho.eduzhixin.com/archives/tag/csst/page/'
headers = {
    'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/128.0.0.0 Safari/537.36 Edg/128.0.0.0'
}

for i in range(1,4):
    # 创建文件目录实例
    purl = url + str(i)
    response = requests.get(url=purl, headers=headers).text
    tree = etree.HTML(response)
    # 解析div列表
    div_list = tree.xpath('/html/body/div/div/div/div/div/div')
    def down(div):
      detail_url = div.xpath('./article/a/@href') # 获取详情页链接
      name = div.xpath('./article/a/@title')# 获取文件名
      ans_path = './ccho/' + name +'.pdf' # 生成文件路径
      detail_page = requests.get(url=detail_url, headers=headers).text
      detail_tree = etree.HTML(detail_page)
      try:
            down_url = detail_tree.xpath('//div[@class="row"]/div/article/div/div/div//strong/a/@href')
            data = requests.get(url=down_url, headers=headers).content
            with open(ans_path, 'wb') as fp:
                fp.write(data)
            print(name, 'is downloaded')
      except:
            print('Unable to download', name, ' , url:', detail_url)
    pool = Pool(5)
    pool.map(down, div_list)
    pool.close()
    pool.join()



欢迎大家指正错误

weixinzr99968 发表于 2024-9-24 17:58

weixinzr99968 发表于 2024-9-24 17:56
# -*- coding:utf-8 -*-
import requests
from lxml import etree



        1.        修复了 url 拼接错误,确保循环时请求正确的页面。
        2.        添加了非法字符过滤,确保文件名不会因为非法字符而报错。
        3.        提取下载链接时增加了检查,避免 IndexError。
        4.        为 requests.get() 添加了异常处理,避免程序崩溃。
        5.        在多线程下载中改进了错误处理和日志输出。

icer233 发表于 2024-9-18 17:50

爬虫思路见https://www.52pojie.cn/thread-1957905-1-1.html

baihedengge 发表于 2024-9-18 09:42

学习了,真厉害。

zk1126853389 发表于 2024-9-18 09:53

感谢分享

woshizhj0451 发表于 2024-9-18 10:38

本来是想学习下爬虫编程的,结果发现这个网站是真不错,在上面答了一会儿题;www

nxyclf 发表于 2024-9-18 11:25

msmvc 发表于 2024-9-18 11:30

虽然试题都作不出来,但是我看透了本质:如果我掌握了X,我就会作Y

W8826 发表于 2024-9-18 13:49

完蛋看不懂啊小白一个

Stars666 发表于 2024-9-18 17:45

感谢大佬分享

aiguohou 发表于 2024-9-18 19:35

感谢分享
页: [1] 2
查看完整版本: 【爬虫】爬取CCHO历年试卷及解析