MyCodery - API de Web Scraping com Navegador Sem Cabeça API

Nossa MyCodery - API de Web Scraping com capacidade de Navegador Sem Cabeça permite que você extraia dados de websites enquanto simula um navegador real Isso permite que você contorne restrições resolva captchas e colete dados de websites dinâmicos com facilidade Perfeito para tarefas de web scraping de alto nível
Use esta API do seu agente de IA via MCP
Funciona com OpenClaw, Claude Code/Desktop, Cursor, Windsurf, Cline e qualquer cliente de IA compatível com MCP.
Docs e configuração
Crie uma skill envolvendo este MCP: https://mcp.zylalabs.com/mcp?apikey=YOUR_ZYLA_API_KEY

Sobre a API:

A nossa MyCodery - API de Web Scraping com capacidade de Navegador Sem Cabeça é a solução perfeita para tarefas de web scraping de alto nível. Esta poderosa API permite que você extraia dados de sites enquanto simula um navegador real. Isso significa que você pode contornar restrições de sites, resolver captchas e raspar sites dinâmicos com facilidade.

A capacidade de navegador sem cabeça da API emula um navegador real, permitindo que ele interaja com páginas da web assim como um usuário humano faria. Isso é particularmente útil para raspar sites que usam JavaScript e outros elementos dinâmicos, além de contornar mecanismos de detecção de bots.

A API também oferece uma ampla gama de ferramentas para extração de dados, permitindo que você extraia facilmente as informações necessárias de páginas da web, incluindo texto, imagens e links. A API também pode ser personalizada para atender às suas necessidades específicas, como extrair dados de elementos específicos em uma página ou seguir links para raspar várias páginas.

A nossa API é fácil de integrar em seus sistemas existentes, seja um aplicativo móvel, site ou aplicativo autônomo. Foi projetada para ser amigável e fácil de usar, tornando-a acessível a desenvolvedores de todos os níveis de habilidade.

Em resumo, nossa API de Web Scraping com capacidade de Navegador Sem Cabeça é a solução perfeita para tarefas de web scraping de alto nível. Com sua capacidade de simular um navegador real, contornar restrições de sites e resolver captchas, esta API torna a raspagem de sites dinâmicos uma tarefa fácil.

O que esta API recebe e o que sua API fornece (entrada/saída)?

Envie a URL que deseja raspar e receba o HTML contido nela em questão de segundos. 

 

Quais são os casos de uso mais comuns desta API?

  1. Inteligência competitiva: Use a API para raspar sites de concorrentes em busca de preços, ofertas de produtos e outras informações relevantes para obter uma vantagem competitiva no seu mercado.

  2. Mercados online: Use a API para raspar sites de mercados online para coletar dados sobre preços, produtos e avaliações de vendedores para comparação de preços e pesquisa de mercado.

  3. Inteligência de negócios: Use a API para raspar sites de notícias de negócios e plataformas de mídia social para acompanhar tendências de mercado, atividades de concorrentes e sentimento dos clientes.

  4. Vagas de emprego: Extraia anúncios de emprego de vários sites de empregos e sites de carreira para criar um banco de dados pesquisável de oportunidades de trabalho, mesmo que o site esteja usando técnicas anti-raspagem.

  5. Imóveis: Extraia listagens de propriedades, preços e dados de localização de sites de imóveis para criar um banco de dados abrangente de informações sobre o mercado imobiliário.

  6. Mineração de dados: Use a API para raspar grandes quantidades de dados de sites públicos para análise e pesquisa, como dados científicos, dados financeiros e mais.

 

Existem limitações nos seus planos?

Além das limitações de chamadas da API por mês, não há outras limitações.

Documentação da API

Endpoints


Retorna o código html de uma url



                                                                            
GET https://pr140-testing.zylalabs.com/api/21/mycodery+-+web+scraping+api+with+headless+browser+api/82/scrape
                                                                            
                                                                        

raspar - Recursos do endpoint

Objeto Descrição
url [Obrigatório]
render_js Opcional
country_code Opcional Select the country you want to set the proxy into. Two letter code (ISO 3166-1 format)
premium_proxy Opcional
Testar endpoint

RESPOSTA DE EXEMPLO DA API

       
                                                                                                        
                                                                                                                                                                                                                                                                                                                                        <!DOCTYPE html><!--[if IE]><![endif]--><!--[if IE 8 ]><html dir="ltr" lang="en" class="ie8"><![endif]--><!--[if IE 9 ]><html dir="ltr" lang="en" class="ie9"><![endif]--><!--[if (gt IE 9)|!(IE)]><!--><html dir="ltr" class="ltr wf-loading wf-playfairdisplay-n9-loading wf-montserrat-n4-loading" lang="en"><!--<![endif]--><head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1"><title>La Chic | Chicago's Prom Headquarters</title>
<base href="//www.lachicchicago.com">
<link rel="canonical" href="https://www.lachicchicago.com">    
<meta http-equiv="X-UA-Compatible" content="IE=edge">

<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin="">
<style>
    #mainslider .scrollingslide img {
        height: 700px !important;
        width:auto !important;
    }
   
</style>
            <link href="https://estylecdn.com/rdoassets/catalog/view/theme/pav_fashion/stylesheet/bootstrap.css" rel="stylesheet">
        <!--    <link rel="stylesheet" href="https://estylecdn.com/ar/fontawesome/4.7/css/font-awesome.min.css">-->
        <link rel="stylesheet" href="https://estylecdn.com/ar/fontawesome/css/all.css" crossorigin="anonymous">
    <link href="https://estylecdn.com/rdoassets/catalog/view/theme/pav_fashion/stylesheet/stylesheet.min.css" rel="stylesheet">

<style>
    /* latin-ext */
@font-face {
  font-family: 'Nunito';
  font-display:swap;
  font-style: normal;
  font-weight: 300;
  src: local('Nunito Light'), local('Nunito-Light'), url(https://fonts.gstatic.com/s/nunito/v10/XRXW3I6Li01BKofAnsSUb-vISTs.woff2) format('woff2');
  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Nunito';
  font-display:swap;
  font-style: normal;
  font-weight: 300;
  src: local('Nunito Light'), local('Nunito-Light'), url(https://fonts.gstatic.com/s/nunito/v10/XRXW3I6Li01BKofAnsSUYevI.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
</style>



    <link href="https://estylecdn.com/rdoassets/catalog/view/theme/pav_fashion/stylesheet/customize/ESC-White-on-White.css" rel="stylesheet">
    <link rel="stylesheet" href="https://estylecdn.com/ar/assetssty/12/escpavmod.min.css">
    <script src="https://connect.facebook.net/signals/config/397495456115138?v=2.9.179&amp;r=stable&amp;domain=www.lachicchicago.com&amp;hme=b8122d5d96cd6f542162ba4f497489972d1ebe228d24c39d34f560e30ae932ce&amp;ex_m=70%2C122%2C107%2C111%2C61%2C4%2C100%2C69%2C16%2C97%2C89%2C51%2C54%2C173%2C176%2C188%2C184%2C185%2C187%2C29%2C101%2C53%2C77%2C186%2C168%2C171%2C181%2C182%2C189%2C132%2C41%2C191%2C192%2C34%2C144%2C15%2C50%2C197%2C196%2C134%2C18%2C40%2C1%2C43%2C65%2C66%2C67%2C71%2C93%2C17%2C14%2C96%2C92%2C91%2C108%2C52%2C110%2C39%2C109%2C30%2C94%2C26%2C169%2C172%2C141%2C86%2C56%2C84%2C33%2C73%2C0%2C95%2C32%2C28%2C82%2C83%2C88%2C47%2C46%2C87%2C37%2C11%2C12%2C13%2C6%2C7%2C25%2C22%2C23%2C57%2C62%2C64%2C75%2C102%2C27%2C76%2C9%2C8%2C80%2C48%2C21%2C104%2C103%2C105%2C98%2C10%2C20%2C3%2C38%2C74%2C19%2C5%2C90%2C81%2C44%2C35%2C85%2C2%2C36%2C63%2C42%2C106%2C45%2C79%2C68%2C112%2C60%2C59%2C31%2C99%2C58%2C55%2C49%2C78%2C72%2C24%2C113" async=""></script><script async="" src="https://connect.facebook.net/en_US/fbevents.js"></script><script data-cfasync="false" src="//ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>

<script data-cfasync="false" src="//ajax.googleapis.com/ajax/libs/jqueryui/1.12.1/jquery-ui.min.js"></script>
<link rel="stylesheet" href="//ajax.googleapis.com/ajax/libs/jqueryui/1.12.1/themes/smoothness/jquery-ui.min.css">



<script data-cfasync="false" async="" src="https://estylecdn.com/ar/js/jquery.invertImages.min.js"></script>

<script data-cfasync="false" src="https://maxcdn.bootstrapcdn.com/bootstrap/3.1.1/js/bootstrap.min.js"></script>
<script data-cfasync="false" async="" src="https://estylecdn.com/rdoassets/catalog/view/javascript/jquery/magnific/jquery.magnific-popup.min.js"></script>

<script data-cfasync="false" async="" src="https://estylecdn.com/ar/assetssty/12/commoncomb.min.js"></script>



<script>
document.addEventListener("DOMContentLoaded", function() {
  var lazyImages = [].slice.call(document.querySelectorAll("img.lazy"));;

  if ("IntersectionObserver" in window && "IntersectionObserverEntry" in window && "intersectionRatio" in window.IntersectionObserverEntry.prototype) {
    let lazyImageObserver = new IntersectionObserver(function(entries, observer) {
      entries.forEach(function(entry) {
        if (entry.isIntersecting) {
          let lazyImage = entry.target;
          lazyImage.src = lazyImage.dataset.src;
          lazyImage.srcset = lazyImage.dataset.srcset;
          lazyImage.classList.remove("lazy");
          lazyImageObserver.unobserve(lazyImage);
        }
      });
    });

    lazyImages.forEach(function(lazyImage) {
      lazyImageObserver.observe(lazyImage);
    });
  }
});


document.addEventListener("DOMContentLoaded", function() {
  var lazyBackgrounds = [].slice.call(document.querySelectorAll(".lazy-background"));

  if ("IntersectionObserver" in window && "IntersectionObserverEntry" in window && "intersectionRatio" in window.IntersectionObserverEntry.prototype) {
    let lazyBackgroundObserver = new IntersectionObserver(function(entries, observer) {
      entries.forEach(function(entry) {
        if (entry.isIntersecting) {
          entry.target.classList.add("visible");
          lazyBackgroundObserver.unobserve(entry.target);
        }
      });
    });

    lazyBackgrounds.forEach(function(lazyBackground) {
      lazyBackgroundObserver.observe(lazyBackground);
    });
  }
});
</script>

    <style>
    .ui-slider { position: relative; text-align: left; }
    .ui-slider .ui-slider-handle { position: absolute; z-index: 2; width: 10px; height: 10px; cursor: default; }
    .ui-slider .ui-slider-range { position: absolute; z-index: 1; font-size: 12px; display: block; border: 0; background-position: 0 0; }
    .ui-slider-horizontal { height: 8px; }
    .ui-slider-horizontal .ui-slider-handle { top: -1px; margin-left: -2px; }
    .ui-slider-horizontal .ui-slider-range { top: 0; height: 100%; }
    .ui-slider-horizontal .ui-slider-range-min { left: 0; }
    .ui-slider-horizontal .ui-slider-range-max { right: 0; }
    
    .ui-slider-horizontal .ui-slider-handle {
        top: -6px;
        margin-left: -2px;
    }

    .ui-slider .ui-slider-handle {
        position: absolute;
        z-index: 2;
        width: 18px;
        height: 18px;
        cursor: default;
    }

    .ui-state-default, .ui-widget-content .ui-state-default{
        border: 1px solid #000000;
       
    }
    </style>
    <link rel="preload" href="https://cdnjs.cloudflare.com/ajax/libs/noUiSlider/15.6.0/nouislider.min.css" as="style" onload="this.rel='stylesheet'">
    <noscript><link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/noUiSlider/15.6.0/nouislider.min.css"></noscript>

 <script src="https://cdnjs.cloudflare.com/ajax/libs/noUiSlider/15.6.0/nouislider.min.js" defer=""></script>
    <script>
        jQuery(document).ready(function($) {
            var slider = document.getElementById('slider-rangeMOB');

            noUiSlider.create(slider, {
                start: [0, 6000],
                connect: true,
                range: {
                    'min': 0,
                    'max': 6000
                },
                format: {
                    to: function (value) {
                        return Math.round(value);
                    },
                    from: function (value) {
                        return Number(value);
                    }
                }
            });

            slider.noUiSlider.on('update', function(values, handle) {
                $('#amountMOB').val('$' + values[0] + ' - $' + values[1]);
            });

            slider.noUiSlider.on('start', function() {
                document.getElementById('priceFilterOnIdMOB').checked = true;
            });

            $('#amountMOB').val('$' + slider.noUiSlider.get()[0] + ' - $' + slider.noUiSlider.get()[1]);
        });
    </script>
<script data-cfasync="false">
    jQuery(function() {
                    // jQuery( "#slider-rangeMOB" ).slider({
            //         range: true,
            //         min: 0,
            //         max: 6000,
            //         values: [ 0, 6000 ],
            //         slide: function( event, ui ) {
            //                 jQuery( "#amountMOB" ).val( "$" + ui.values[ 0 ] + " - $" + ui.values[ 1 ] );
            //         },
            //         start: function(event, ui) {
            //                 document.getElementById('priceFilterOnIdMOB').checked=true;
            //         }
            // });
            // jQuery( "#amount" ).val( "$" + jQuery( "#slider-rangeMOB" ).slider( "values", 0 ) +
            //         " - $" + jQuery( "#slider-rangeMOB" ).slider( "values", 1 ) );



            jQuery('.attChk').change(function() {
                if(jQuery(this).is(":checked")) {
                    jQuery(this).parent().parent().parent().prev().find('.attClear').html(" <a href='#' class=attClearBtn>Clear</a>");
                }
            });
            $(".filterToggle").click(function () {
                $header = $(this);
                $content = $header.next('div');
                $content.slideToggle(500, function () {
                    $("span.filterInd",$header).text(function () {
                        return $content.is(":visible") ? "-" : "+";
                    });
                });
            });
            $(".filterToggleCB").click(function () {
                $header = $(this).parent();
                $content = $header.next('div');
                $content.slideT...
                                                                                                                                                                                                                    
                                                                                                    

Raspar - TRECHOS DE CÓDIGO


curl --location --request GET 'https://zylalabs.com/api/21/mycodery+-+web+scraping+api+with+headless+browser+api/82/scrape?url=https://www.youtube.com/' --header 'Authorization: Bearer YOUR_API_KEY' 


    

Chave de acesso à API e autenticação

Após se cadastrar, cada desenvolvedor recebe uma chave de acesso à API pessoal, uma combinação única de letras e dígitos para acessar nosso endpoint de API. Para autenticar com a MyCodery - API de Web Scraping com Navegador Sem Cabeça API basta incluir seu token Bearer no cabeçalho Authorization.
Cabeçalhos
Cabeçalho Descrição
Authorization [Obrigatório] Deve ser Bearer access_key. Veja "Sua chave de acesso à API" acima quando você estiver inscrito.

Preços simples e transparentes

Sem compromisso de longo prazo. Faça upgrade, downgrade ou cancele a qualquer momento. O teste gratuito inclui até 50 requisições.

🚀 Empresarial

A partir de
$ 10.000/Ano


  • Volume personalizado
  • Limite de taxa personalizado
  • Suporte ao cliente especializado
  • Monitoramento de API em tempo real

Recursos favoritos dos clientes

  • ✔︎ Pague apenas por requisições bem-sucedidas
  • ✔︎ Teste 7 dias gratis
  • ✔︎ Suporte multilíngue
  • ✔︎ Uma chave de API, todas as APIs.
  • ✔︎ Painel intuitivo
  • ✔︎ Tratamento de erros abrangente
  • ✔︎ Documentação amigável para desenvolvedores
  • ✔︎ Integração com Postman
  • ✔︎ Conexões HTTPS seguras
  • ✔︎ Alta disponibilidade

MyCodery - API de Web Scraping com Navegador Sem Cabeça API FAQs

O endpoint GET Scrape retorna o código HTML completo da URL especificada Isso inclui todo o texto imagens links e outros elementos presentes na página da web permitindo que os usuários extraiam qualquer informação necessária

Os dados da resposta estão estruturados como um único documento HTML Os usuários podem analisar este documento para acessar elementos específicos, como cabeçalhos, parágrafos, imagens e links, usando técnicas padrão de análise de HTML

O parâmetro principal para o endpoint GET Scrape é a URL da página da web a ser raspada Os usuários podem personalizar suas solicitações especificando parâmetros adicionais, como cabeçalhos ou strings de agente do usuário, para simular diferentes comportamentos de navegador

O endpoint GET Scrape proporciona acesso a todas as informações disponíveis publicamente na página da web especificada, incluindo conteúdo de texto, imagens, links e metadados. Isso o torna adequado para várias tarefas de extração de dados

A precisão dos dados é mantida pelo uso de um navegador sem interface que simula interações reais de usuários Isso ajuda a contornar restrições e garante que a versão mais atual da página da web seja recuperada reduzindo a probabilidade de dados desatualizados ou incorretos

Casos de uso típicos incluem análise competitiva pesquisa de mercado agregação de listagens de empregos e mineração de dados para tendências Os usuários podem extrair informações específicas para análise ou relatórios com base em suas necessidades

Os usuários podem utilizar os dados HTML retornados empregando bibliotecas de análise HTML (como BeautifulSoup em Python) para extrair elementos específicos, como texto, imagens ou links, com base em suas necessidades para análise ou armazenamento adicionais

A API utiliza um navegador sem interface para garantir que os dados obtidos reflitam o estado ao vivo da página da web Além disso os usuários podem implementar suas próprias verificações de validação após a extração de dados para garantir a precisão e relevância

Perguntas Frequentes Gerais

O Zyla API Hub é como uma grande loja de APIs, onde você pode encontrar milhares delas em um só lugar. Também oferecemos suporte dedicado e monitoramento em tempo real de todas as APIs. Após se cadastrar, você pode escolher quais APIs deseja usar. Lembre-se apenas de que cada API precisa de sua própria assinatura. Mas se você se inscrever em várias, usará a mesma chave para todas elas, facilitando as coisas para você.

Os preços são listados em USD (Dólar Americano), EUR (Euro), CAD (Dólar Canadense), AUD (Dólar Australiano) e GBP (Libra Esterlina). Aceitamos todos os principais cartões de débito e crédito. Nosso sistema de pagamento usa a mais recente tecnologia de segurança e é operado pela Stripe, uma das empresas de pagamento mais confiáveis do mundo. Se tiver problemas para pagar com cartão, entre em contato conosco em [email protected]


Além disso, se você já tiver uma assinatura ativa em qualquer uma dessas moedas (USD, EUR, CAD, AUD, GBP), essa moeda será mantida para assinaturas subsequentes. Você pode alterar a moeda a qualquer momento, desde que não tenha assinaturas ativas.

A moeda local exibida na página de preços é baseada no país do seu endereço IP e é fornecida apenas como referência. Os preços reais são em USD (Dólar Americano). Ao efetuar o pagamento, a cobrança aparecerá no extrato do seu cartão em USD, mesmo que você veja o valor equivalente em sua moeda local em nosso site. Isso significa que você não pode pagar diretamente com sua moeda local.

Ocasionalmente, o banco pode recusar a cobrança devido às configurações de proteção contra fraude. Sugerimos contatar seu banco inicialmente para verificar se estão bloqueando nossas cobranças. Você também pode acessar o Portal de Cobrança e alterar o cartão associado para realizar o pagamento. Se isso não funcionar e precisar de mais ajuda, entre em contato com nossa equipe em [email protected]

Os preços são determinados por uma assinatura recorrente mensal ou anual, dependendo do plano escolhido.

As chamadas de API são descontadas do seu plano com base nas requisições bem-sucedidas. Cada plano possui um número específico de chamadas por mês. Apenas chamadas bem-sucedidas, indicadas por uma resposta com Status 200, serão contabilizadas, garantindo que falhas não afetem sua cota mensal.

O Zyla API Hub funciona com um sistema de assinatura mensal recorrente. Seu ciclo de cobrança começa no dia em que você compra um dos planos pagos e será renovado no mesmo dia do mês seguinte. Portanto, cancele sua assinatura com antecedência se quiser evitar cobranças futuras.

Para fazer upgrade do seu plano atual, acesse a página de preços da API e selecione o novo plano desejado. O upgrade é instantâneo, permitindo aproveitar imediatamente os recursos do novo plano. Observe que as chamadas restantes do plano anterior não serão transferidas; você será cobrado pelo valor integral do novo plano.

Para verificar quantas chamadas de API restam para o mês atual, consulte o campo 'X-Zyla-API-Calls-Monthly-Remaining' no cabeçalho da resposta. Por exemplo, se seu plano permite 1.000 requisições por mês e você usou 100, este campo no cabeçalho da resposta indicará 900 chamadas restantes.

Para ver o número máximo de requisições de API que seu plano permite, verifique o cabeçalho de resposta 'X-Zyla-RateLimit-Limit'. Por exemplo, se seu plano inclui 1.000 requisições por mês, este cabeçalho exibirá 1.000.

O cabeçalho 'X-Zyla-RateLimit-Reset' mostra o número de segundos até seu limite de taxa ser redefinido. Isso informa quando sua contagem de requisições começará do zero. Por exemplo, se exibir 3.600, significa que restam 3.600 segundos até o limite ser redefinido.

Sim, você pode cancelar seu plano a qualquer momento acessando sua conta e selecionando a opção de cancelamento na página de Cobrança. Observe que upgrades, downgrades e cancelamentos têm efeito imediato. Além disso, após o cancelamento, você não terá mais acesso ao serviço, mesmo que ainda tenha chamadas restantes na sua cota.

Você pode nos contatar via chat para receber assistência imediata. Estamos online de 8h às 17h (EST). Se nos contatar após esse horário, retornaremos o mais rápido possível. Além disso, você pode enviar um e-mail para [email protected]

Para oferecer a oportunidade de experimentar nossas APIs sem compromisso, oferecemos um teste gratuito de 7 dias que permite realizar até 50 chamadas de API sem custo. Esse teste pode ser usado apenas uma vez; recomendamos aplicá-lo à API que mais interessa. Embora a maioria das APIs ofereça teste gratuito, algumas podem não oferecer. O teste termina após 7 dias ou quando você atingir 50 requisições, o que ocorrer primeiro. Se atingir o limite, será necessário "Iniciar seu plano pago" para continuar. Você encontra esse botão no perfil em Assinatura -> Escolha a API -> aba Preços. Se não cancelar até o 7º dia, sua assinatura será cobrada automaticamente, liberando todas as chamadas do plano.

Após 7 dias, será cobrado o valor total do plano ao qual você estava inscrito durante o teste. Portanto, é importante cancelar antes do término do período. Solicitações de reembolso por esquecimento de cancelamento não são aceitas.

Ao assinar um teste gratuito de API, você pode fazer até 50 chamadas. Se desejar fazer chamadas adicionais além desse limite, a API solicitará que você "Inicie seu plano pago". Você encontra o botão no perfil em Assinatura -> Escolha a API -> aba Preços.

As Ordens de Pagamento são processadas entre os dias 20 e 30 de cada mês. Se você enviar sua solicitação antes do dia 20, seu pagamento será processado dentro desse período.


APIs relacionadas


Você também pode gostar