【发布时间】:2020-05-27 11:28:23
【问题描述】:
我正在尝试抓取在a 标记下具有h3 标记的网页。我得到了a 标签就好了,但是当我试图得到h3 的innerText 时,我得到了一个undefined 值。
这就是我要抓取的内容:
const puppeteer = require('puppeteer');
const pageURL = "https://producthunt.com";
const webScraping = async pageURL => {
const browser = await puppeteer.launch({
headless: false,
arges: ["--no-sandbox"]
});
const page = await browser.newPage();
let dataObj = {};
try {
await page.goto(pageURL, { waitUntil: 'networkidle2' });
const publishedNews = await page.evaluate(() => {
const newsDOM = document.querySelectorAll("main ul li");
let newsList = [];
newsDOM.forEach(linkElement => {
const text = linkElement.querySelector("a").textContent;
const innerText = linkElement.querySelector("a").innerText;
const url = linkElement.querySelector("a").getAttribute('href');
const title = linkElement.querySelector("h3").innerText;
console.log(title);
newsList.push({
title,
text,
url
});
});
return newsList;
});
dataObj = {
amount: publishedNews.length,
publishedNews
};
} catch (e) {
console.log(e);
}
console.log(dataObj);
browser.close();
return dataObj;
};
webScraping(pageURL).catch(console.error);
控制台日志运行良好,但 puppeteer 抛出:
Cannot read property 'innerText' of null
【问题讨论】:
标签: web-scraping web-crawler puppeteer domcrawler