繁体   English   中英

PUPPETER - 循环内的随机超时不起作用

[英]PUPPETER - Random timeout inside loop not working

所以,我有这样的代码(只有这部分不能正常工作)

(async () => {
  const browser = await puppeteer.launch({
    headless: false,
    // slowMo: 250 // slow down by 250ms
  });
  const page = await browser.newPage();
//some code

// CODE ABOVE WORKS, here is what is not working inside of it:

await page.evaluate(() => {
    function delay(timeout) {
      return new Promise((resolve) => {
        setTimeout(resolve, timeout);
      });
    }
    function randomInteger(min, max) {
      return Math.floor(Math.random() * (max - min + 1)) + min;
    }
    const farms = document.querySelectorAll(".startButton");
    for (let i = 0; i < 3; i++) {
      for (const farm of farms) {
        farm.click();
      }
      delay(randomInteger(820000, 920000));
    }
  });
})();

我想要的是,到 select 与此 class 的所有按钮,单击它们,然后等待一段时间,然后再次单击它们,但它看起来像延迟 function 代码在这里,或其他部分未执行它工作得很好,我知道哪里有问题,我请求你的帮助::D

#编辑

代码(如@Sheun Aluko 所说,添加了异步和等待)很好,由于网站安全系统,它无法正常工作,所以我需要应用刷新/转到同一页面的新修复程序,并更改循环顺序,也许是它效率不高,但它可以 100% 工作。 这是示例:

(async () => {
  const browser = await puppeteer.launch({
    headless: false,
    // slowMo: 250 // slow down by 250ms
  });

//SOME CODE THAT WORKS
//OUR PART BELOW

  for (let i = 0; i < 150; i++) {
    await page.goto("SOME_URL", {
      waitUntil: "networkidle2",
    });
    await page.evaluate(async (page) => {
      function delay(timeout) {
        return new Promise((resolve) => {
          setTimeout(resolve, timeout);
        });
      }
      function randomInteger(min, max) {
        return Math.floor(Math.random() * (max - min + 1)) + min;
      }

      const farms = document.querySelectorAll('SOME_SELECTOR');

      for (const farm of farms) {
        farm.click();
      }
      await delay(randomInteger(840000, 960000));
    });
  }
})

我可以看到delay function 返回 promise。 在最后一行,我相信您应该改为调用await delay(randomInteger(820000, 920000))以便循环在下一次迭代之前实际等待。

针对您提到的错误,这是因为您传递给 page.evaluate 的 function 未标记为异步。 我对 Puppeteer 并不完全熟悉,但您可以尝试将提供的 function 标记为异步 .. 即:

await page.evaluate( async () => { 
   ....
})

暂无
暂无

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

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