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.
Envie a URL que deseja raspar e receba o HTML contido nela em questão de segundos.
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.
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.
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.
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.
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.
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.
Além das limitações de chamadas da API por mês, não há outras limitações.
Retorna o código html de uma url
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 |
<!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&r=stable&domain=www.lachicchicago.com&hme=b8122d5d96cd6f542162ba4f497489972d1ebe228d24c39d34f560e30ae932ce&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...
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'
| Cabeçalho | Descrição |
|---|---|
Authorization
|
[Obrigatório] Deve ser Bearer access_key. Veja "Sua chave de acesso à API" acima quando você estiver inscrito. |
Sem compromisso de longo prazo. Faça upgrade, downgrade ou cancele a qualquer momento. O teste gratuito inclui até 50 requisições.
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
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.
Nível de serviço:
100%
Tempo de resposta:
2.507ms
Nível de serviço:
100%
Tempo de resposta:
256ms
Nível de serviço:
100%
Tempo de resposta:
878ms
Nível de serviço:
100%
Tempo de resposta:
2.697ms
Nível de serviço:
100%
Tempo de resposta:
3.158ms
Nível de serviço:
100%
Tempo de resposta:
3.976ms
Nível de serviço:
100%
Tempo de resposta:
546ms
Nível de serviço:
100%
Tempo de resposta:
2.052ms
Nível de serviço:
100%
Tempo de resposta:
1.374ms
Nível de serviço:
100%
Tempo de resposta:
8.219ms
Nível de serviço:
100%
Tempo de resposta:
20.003ms
Nível de serviço:
100%
Tempo de resposta:
20.003ms
Nível de serviço:
100%
Tempo de resposta:
5.878ms
Nível de serviço:
100%
Tempo de resposta:
11.821ms
Nível de serviço:
100%
Tempo de resposta:
297ms
Nível de serviço:
100%
Tempo de resposta:
620ms
Nível de serviço:
100%
Tempo de resposta:
173ms
Nível de serviço:
100%
Tempo de resposta:
10.604ms
Nível de serviço:
100%
Tempo de resposta:
1.272ms
Nível de serviço:
100%
Tempo de resposta:
1.151ms