nodejs写爬虫

javascript 复制代码
const axios = require('axios');
const fs = require('fs');
const path = require('path');
const cheerio = require('cheerio');
const { str } = require('./dataStr');


async function getImageUrls() {
    const $ = cheerio.load(str)
    let imageUrls = [];
    $('img').each((index, element) => {
        const imgSrc = $(element).attr('src'); // 获取每张图片的源地址
        if (/^https/.test(imgSrc)) { // 判断是否为外部图片
            imageUrls.push(imgSrc);
        } else if (/^\//.test(imgSrc)) { // 判断是否为相对路径
            imageUrls.push(`https:${imgSrc}`);
        }
    });
    return imageUrls;
}

const sleep = time => {
    return new Promise(function (resolve, reject) {
        setTimeout(function () {
            resolve();
        }, time);
    })
}

async function test() {
    try {
        const urls = await getImageUrls();
        console.log('urls', urls)
        if (urls !== null) {
            for (let i = 0; i < urls.length; i++) {
                const fileName = `image_${i}.gif`; // 自定义保存图片的名称及格式
                const filePath = path.join('./images2', fileName); // 构造本地保存路径
                await sleep(1500)
                try {
                    const response = await axios({
                        method: 'get',
                        url: urls[i],
                        responseType: 'stream' // 流式传输图片数据
                    });

                    response.data.pipe(fs.createWriteStream(filePath)); // 将图片数据写入本地文件
                    console.log(`Successfully downloaded ${fileName}`);
                } catch (error) {
                    console.log(`Failed to download ${fileName}: ${error}`);
                }
            }
        }
    } catch (error) {
        console.log(error);
    }
}

test();
相关推荐
666HZ6669 分钟前
正则表达式使用示例
javascript·vue.js·正则表达式
睡不着的可乐13 分钟前
面向对象与面向过程、函数式编程
前端·javascript·vue.js
爱分享的程序员19 分钟前
前端面试专栏-工程化:25.项目亮点与技术难点梳理
前端·javascript·面试
ZHENGZJM37 分钟前
使用JS编写动态表格
开发语言·前端·javascript
小彭努力中1 小时前
153.在 Vue 3 中使用 OpenLayers + Cesium 实现 2D/3D 地图切换效果
前端·javascript·vue.js·3d·ecmascript·echarts
DoraBigHead1 小时前
原型与原型链 · 千年武学秘籍终解封!
前端·javascript·面试
独立开阀者_FwtCoder3 小时前
2025年每个开发者都必须知道的100多个JavaScript术语(附示例)
前端·javascript·vue.js
3Katrina3 小时前
React大厂面试问答系列之Hooks
前端·javascript·面试
LuckySusu3 小时前
【js篇】JavaScript 中的包装类型详解var、let、const 的区别详解
前端·javascript
Mintopia3 小时前
Three.js 流水效果制作:从像素到波澜的魔法之旅
前端·javascript·three.js