我正在尝试制作一个小的脚本,以便在搜索“'什么是'+ Word”之后点击随机的Google搜索结果。我什么都做不到,无法得到想要的结果,哎呀,我什至无法获得脚本来单击单个Google搜索结果!
我在这里尝试了多种操作,例如将所有搜索结果收集在一个数组中,然后单击一个随机的(未收集到一个数组中),单击部分文本的元素(https://未显示结果) )以及许多其他可在Python中运行但无法在此处运行的解决方案。
const puppeteer = require('puppeteer');
const searchbar = "#tsf > div:nth-child(2) > div > div.RNNXgb > div > div.a4bIc > input"
async function gsearch() {
const browser = await puppeteer.launch({headless:false, args:['--no-sandbox', '--disable-setuid-sandbox']});
const page = await browser.newPage();
await page.goto('https://google.com');
var fs = require("fs");
var array = fs.readFileSync("words.txt").toString().split('\n');
var random = array[Math.floor(Math.random() * array.length)]
await page.click(searchbar)
await page.keyboard.type("what is " + random);
await page.waitFor(1000);
await page.evaluate(() => {
let elements = $('LC20lb').toArray();
for (i = 0; i < elements.length; i++) {
$(elements[i]).click();
}
})
}
gsearch();
(忽略任何缩进继承错误,我发誓在VSC中看起来更干净)
预期点击随机搜索结果。最终什么也没做,也许是一个或两个错误,仅此而已。
答案 0 :(得分:0)
LC20lb
不是html标记,它应该是h3
的类名,通过使用$()
,您是否尝试使用jQuery选择元素?改用document.querySelectorAll()
。
const puppeteer = require('puppeteer');
const fs = require("fs");
async function gsearch() {
const browser = await puppeteer.launch({
headless: false,
args: ['--no-sandbox', '--disable-setuid-sandbox']
});
const page = await browser.newPage();
await page.goto('https://google.com');
var array = fs.readFileSync("words.txt").toString().split('\n');
var random = array[Math.floor(Math.random() * array.length)];
// simple selector for search box
await page.click('[name=q]');
await page.keyboard.type("what is " + random);
// you forgot this
await page.keyboard.press('Enter');
// wait for search results
await page.waitForSelector('h3.LC20lb', {timeout: 10000});
await page.evaluate(() => {
let elements = document.querySelectorAll('h3.LC20lb')
// "for loop" will click all element not random
let randomIndex = Math.floor(Math.random() * elements.length) + 1
elements[randomIndex].click();
})
}