Skip to content

Latest commit

 

History

History
212 lines (142 loc) · 6.22 KB

README.md

File metadata and controls

212 lines (142 loc) · 6.22 KB

Lab Puppeteer

O objetivo deste lab é ensinar como utilizar a biblioteca Puppeteer para realizar raspagem de dados (Web scrape) e automações na Web.

O que é

Puppeteer é uma biblioteca do Google feita para ser utilizado com o nodeJS que consiste em um navegador "autônomo" que pode ser programado para executar uma série de ações automatizadas exatamente como um usuário, extraindo dados de páginas na Web, além de permitir o acesso a informações fornecidas por um navegador durante a navegação pela Web.

Tecnologias utilizadas

Onde Aplicar

Este projeto pode ser aplicado em diversas situações:

  • Testes automatizados/Interações automatizadas
  • Web scraping
  • Geração de Screenshots e/ou PDFs

Sumário

Instalação

Siga as orientações de configuração do ambiente para assegurar a preparação do desenvolvimento do projeto.

Windows:

Instale o setup da versão mais recente do Node.js nesse link: https://nodejs.org/en/download

Depois, execute esse comando no PowerShell para verificar a versão:

node -v
npm -v

Linux:

Execute esse comando no shell para instalar curl:

sudo apt update
sudo apt install nodejs
sudo apt install npm

Para verificar a instalação utilize:

node -v
npm -v

Important

Essa instalação serve apenas para distribuição Ubuntu/Debian

Exemplo básico de código

Nessa seção vamos explicar em detalhes o código básico para utilizar o Puppeteer. Observe que todo o processo é inserido em uma função assíncrona, que no exemplo abaixo, é nomeada como funcao-a-executar.

const puppeteer = require('puppeteer');

async function funcao-a-executar() {
    const browser = await puppeteer.launch({ timeout: 1000, headless: false });
    const page = await browser.newPage();
    await page.goto('https://exemplo.com', 
         { waitUntil: ['networkidle0', 'domcontentloaded'], timeout: 10000 });
    await browser.close();
}

funcao-a-executar();

Agora vamos entender cada parte desse código

Importação da biblioteca

const puppeteer = require('puppeteer');

Isso fará com que, dentro da constante puppeteer, todas as funções da biblioteca fiquem armazenadas, por isso, toda vez que for requisitada, irá carregar consigo tudo do puppeteer.

Estruturas de codigo funcional

Para começar, é importante ressaltar que a biblioteca tem algumas exigências. Tudo deve estar contido em uma função async:

async function nomeDaFuncao(){
  await ...
}

Important

Os processos realizados com o Puppteer são assíncronos, uma vez que as requisições feitas por um navegador devem demorar algum tempo para serem respondidas e não queremos travar o ambiente de execução de código do Node.js. Dessa forma, para evitar esse transtorno, o comando await é indispensável para o processamento utilizando a biblioteca.

Esse é um comando específico para abrir um navegador.

const browser = await puppeteer.launch({ timeout: 1000, headless: false });

headless pode ser mudado para "new", com o intuito de não ser exibida uma tela de navegador

Para que seja funcional, outro requisito nessesário é colocar um comando no início de cada linha de comando

const variavel = await comando
// ou
await comando

Agora, vamos introduzir comandos específicos

  • Abertura de uma nova guia
const page = await browser.newPage();
  • Ir para uma nova url na nova guia
await page.goto('url')
  • Tirar uma screenshot
await page.screenshot({ path: 'caminhoDoArquivo' });
  • Gerar um pdf da página
await page.pdf({ path: 'caminhoDoArquivo', format: 'A4' });
  • Preencher um input
await page.locator("path do html").fill('o que sera escrito');
  • Seleção de um elemento para uma ação posterior
const nomeDaVariavel = await page.waitForSelector('path do html');
  • Comando para clicar em um elemento pré-selecionado (feito no exemplo acima)
await nomeDaVariavel.click();
  • Comando para capturar informações do site
const nomeDaVariavel = await page.evaluate (() => {
const NomeDaVariavel = document.querySelector("path do html");
return NomeDaVariavel
}
  • Comando para esperar ligaçoes exteriores com a internet cessarem
await page.waitForNetworkIdle({concurrency: quantidade de atividades simultâneas, idleTime: tempo de inatividade })

path do html se refere ao caminho de divs, classes e ids até a chegada ao elemento que você quer

Projetos

Esse lab traz vários exemplos de uso do Puppeteer. Cada projeto tem seu roadmap próprio, por isso, cada um deles tem seu próprio readme. A relação dos exemplos segue abaixo:

Nivel 1

  • Interagindo com a pagina - Programa que mostra o funcionamento de uma aplicação a qual clica em um botão
  • Google forms - Programa que prenche 500 vezes um formulário do google
  • Gerador de pdf - Progarama que recebe uma url e retorna um pdf da página
  • Prencher input - Programa que prenche um input com um texto específico

Nivel 2

  • Musica - Programa que faz a conversão da url de uma música no Deezer e devolve a url da mesma música no Spotfy

Nivel 3

Contato