自动化Google外卖下载

Pri*_*514 5 automation google-apps-script puppeteer

有没有办法以编程方式启动/安排Google外卖下载(所有46种以上服务)数据

https://takeout.google.com/

我想定期备份此数据(本地或Google云端硬盘)

可以Puppeteer被用来在没有从谷歌API的用户点击自动化?

use*_*095 4

是的,这绝对是可能的。我建议使用无头浏览器,例如 Selenium 或 Puppeteer。为了实现这一目标,需要采取以下几个步骤:

1) 自动登录 Google(如果需要)
2) 自动导航到 Google Takeout 并下载数据
3 解析数据
4) 编写脚本,以便您可以定期自动化整个过程。

编写网络爬虫时还需要注意以下几点:

在无头模式下运行浏览器时,提供的 HTML 可能与非无头模式运行的浏览器不同。换句话说,DOM 元素上的属性可以以不同的方式命名,并且由于您使用这些属性来自动执行诸如选择和单击之类的操作 - 您的代码将需要更改。因此,通过浏览器检查元素是一个很好的起点,但是在无头模式下运行时,您可能需要调整属性的名称,这对入门很有帮助。例如,以下代码摘录显示了用两种方式为 Puppeteer 编写的用于登录 Google 的相同代码。一种是无头写,一种是非无头写:

无头模式:

(async () => {
    const browser = await puppeteer.launch();
    const page = await browser.newPage();
    await page.goto('https://takeout.google.com');


    await page.waitForSelector('input[type=email]')
    await page.type('input[type=email]', process.env.GOOGLE_USER)
    await page.click('#next')

    await page.waitForSelector('#Passwd', { visible: true })
    await page.type('#Passwd', process.env.GOOGLE_PWD);
    await page.waitForSelector('#signIn', { visible: true })
    await page.click('#signIn');

    await page.waitForNavigation()
    await browser.close();

})();
Run Code Online (Sandbox Code Playgroud)

非无头模式:

(async () => {
    const browser = await puppeteer.launch({ headless: false, slowMo: 50 })
    const page = await browser.newPage()
    await page.goto('https://takeout.google.com');


    await page.waitForSelector('input[type="email"]')
    await page.type('input[type="email"]', process.env.GOOGLE_USER)
    await page.click('#identifierNext')

    await page.waitForSelector('input[type="password"]', { visible: true })
    await page.type('input[type="password"]', process.env.GOOGLE_PWD)
    await page.waitForSelector('#passwordNext', { visible: true })
    await page.click('#passwordNext')


    await page.waitForNavigation()
    await browser.close()
})()
Run Code Online (Sandbox Code Playgroud)