使用nodeJS下载图片

javascript 复制代码
const http = require('http');
const https = require("https");
const cheerio = require('cheerio');
const request = require('request');
const fs = require('fs');

function filterData(data) {
    const $ = cheerio.load(data);
    let textLi = '';
    $('.goods-list-wrap .gl-item img.item-pic').each((index, el) => {
        let imgurl = $(el).attr('data-original');
        console.log($(el).attr('data-original'))
        textLi += $(el).attr('data-original') + "\n";
        console.log(imgurl.split('/')[imgurl.split('/').length - 1], 'fhg')
        let fileName = "./img/" + imgurl.split('/')[imgurl.split('/').length - 1];
        download_img('https:' + imgurl, fileName)
    })
    console.log($('#title-category').text(), 'text')
    fs.writeFile(`${$('#title-category').text()}.txt`, textLi, (err) => {
            if (err) throw err;
            console.log('文本文件已创建并写入数据');
        })
        // console.log(data);
}

// 下载图片
function download_img(img_url, file_name) {
    request(img_url).pipe(fs.createWriteStream(file_name)).on('close', function() {
        console.log('pic saved!')
    })
}
const server = http.createServer((req, res) => {
    let data = "";
    https.get("https://lists.meizu.com/page/list?categoryid=76", (result) => {
        result.on("data", (chuck) => {
            data += chuck;
        })

        result.on("end", () => {
            filterData(data);
        })
    })
})


server.listen(8080, () => {
    console.log("locallhost:8080")
})
相关推荐
濮水大叔7 天前
VonaJS AOP编程:全局中间件全攻略
typescript·nodejs·nestjs
ercom16 天前
mac上安装nvm后,nvm list available 输出的N/A信息
nodejs
濮水大叔18 天前
Node生态中最优雅的数据库事务处理机制
typescript·nodejs·nestjs
濮水大叔19 天前
VonaJS提供的读写分离,直观,优雅🌼
typescript·nodejs·nestjs
濮水大叔22 天前
VonaJS多租户同时支持共享模式和独立模式
typescript·nodejs·nestjs
PegasusYu23 天前
Electron使用WebAssembly实现CRC-16 CCITT-FALSE校验
electron·nodejs·wasm·webassembly·crc16·crc-16·ccitt false
濮水大叔24 天前
在Vona ORM中实现多数据库/多数据源
typescript·nodejs·nestjs
爱隐身的官人1 个月前
ctfshow - web - nodejs
前端·nodejs·ctf