繁体   English   中英

使用 puppeteer 访问从 web 抓取返回的数组的特定索引

[英]Access specific index of array returned from web scrape using puppeteer

这是我的脚本 - 它使用 puppeteer 抓取亚马逊以检查产品可用性

const puppeteer = require('puppeteer');


//URL
scrape('https://www.amazon.co.uk/PlayStation-9395003-5-Console/dp/B08H95Y452/ref=sr_1_1?dchild=1&keywords=ps5&qid=1613570801&sr=8-1');

/**
 *
 * Scrape PS5
 *
 */
async function scrape(url)
{

    const browser = await puppeteer.launch();
    const page = await browser.newPage();
    await page.goto(url);

        //get availability
        const [el2] = await page.$x('//*[@id="availability"]/span');
        const txt1 = el2.getProperty('textContent');
        const rawTxt1 = (await txt1)._remoteObject.value;

        //log data
        console.log({rawTxt1});

        //close browser
        browser.close();

}

我登录后它会将其返回到控制台

在此处输入图像描述

我希望它只返回“当前不可用”

尝试这个

async function scrape(url)
{

    const browser = await puppeteer.launch();
    const page = await browser.newPage();
    await page.goto(url);
    await page.waitForSelector("div#availability")
    const  result = await page.evaluate(()=>{
        return Array.from(document.querySelectorAll("div#availability span.a-size-medium")).map((el)=> el.innerText)
    });
    //log data
    console.log(result)

        //close browser
        browser.close();

}

Output:

["Currently unavailable."]

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM