抓取 Google 搜索可提供基本的 SERP 分析、SEO 优化和数据收集功能。现代抓取工具使这个过程更快、更可靠。
我们的一位社区成员撰写了此博客,作为对 Crawlee 博客的贡献。如果您想向 Crawlee 博客贡献此类博客,请通过我们的 Discord 频道与我们联系。
在本指南中,我们将使用 Crawlee for Python 创建一个 Google 搜索抓取工具,可以处理结果排名和分页。
我们将创建一个抓取工具:
安装 Crawlee 所需的依赖项:
pipx install crawlee[beautifulsoup,curl-impersonate]
使用 Crawlee CLI 创建一个新项目:
pipx run crawlee create crawlee-google-search
出现提示时,选择 Beautifulsoup 作为您的模板类型。
导航到项目目录并完成安装:
cd crawlee-google-search poetry install
首先,让我们定义提取范围。谷歌的搜索结果现在包括地图、名人、公司详细信息、视频、常见问题和许多其他元素。我们将重点分析带有排名的标准搜索结果。
这是我们要提取的内容:
我们来验证一下是否可以从页面的HTML代码中提取必要的数据,或者是否需要更深入的分析或JS渲染。请注意,此验证对 HTML 标签敏感:
根据从页面获取的数据,所有必要的信息都存在于 HTML 代码中。因此,我们可以使用beautifulsoup_crawler。
我们将提取的字段:
首先,让我们创建爬虫配置。
我们将使用 CurlImpersonateHttpClient 作为带有预设标头的 http_client,并模拟与 Chrome 浏览器相关的内容。
我们还将配置 ConcurrencySettings 来控制抓取攻击性。这对于避免被 Google 屏蔽至关重要。
如果您需要更集中地提取数据,请考虑设置ProxyConfiguration。
pipx install crawlee[beautifulsoup,curl-impersonate]
首先我们来分析一下需要提取的元素的HTML代码:
可读 ID 属性和生成 类名和其他属性之间存在明显区别。创建用于数据提取的选择器时,您应该忽略任何生成的属性。即使您已经了解到 Google 已经使用特定的生成标签 N 年了,您也不应该依赖它 - 这反映了您编写健壮代码的经验。
现在我们了解了 HTML 结构,让我们来实现提取。由于我们的爬虫只处理一种类型的页面,因此我们可以使用 router.default_handler 来处理它。在处理程序中,我们将使用 BeautifulSoup 迭代每个搜索结果,在保存结果时提取标题、url 和 text_widget 等数据。
pipx run crawlee create crawlee-google-search
由于 Google 结果取决于搜索请求的 IP 地理位置,因此我们不能依赖链接文本进行分页。我们需要创建一个更复杂的 CSS 选择器,无论地理位置和语言设置如何,它都可以工作。
max_crawl_depth 参数控制我们的爬虫应该扫描多少页面。一旦我们有了强大的选择器,我们只需获取下一页链接并将其添加到爬虫队列中即可。
要编写更高效的选择器,请学习 CSS 和 XPath 语法的基础知识。
cd crawlee-google-search poetry install
由于我们希望以方便的表格格式(例如 CSV)保存所有搜索结果数据,因此我们可以在运行爬虫后立即添加 export_data 方法调用:
from crawlee.beautifulsoup_crawler import BeautifulSoupCrawler from crawlee.http_clients.curl_impersonate import CurlImpersonateHttpClient from crawlee import ConcurrencySettings, HttpHeaders async def main() -> None: concurrency_settings = ConcurrencySettings(max_concurrency=5, max_tasks_per_minute=200) http_client = CurlImpersonateHttpClient(impersonate="chrome124", headers=HttpHeaders({"referer": "https://www.google.com/", "accept-language": "en", "accept-encoding": "gzip, deflate, br, zstd", "user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/131.0.0.0 Safari/537.36" })) crawler = BeautifulSoupCrawler( max_request_retries=1, concurrency_settings=concurrency_settings, http_client=http_client, max_requests_per_crawl=10, max_crawl_depth=5 ) await crawler.run(['https://www.google.com/search?q=Apify'])
虽然我们的核心爬虫逻辑有效,但您可能已经注意到我们的结果目前缺乏排名位置信息。为了完成我们的抓取工具,我们需要通过使用请求中的 user_data 在请求之间传递数据来实现正确的排名位置跟踪。
让我们修改脚本来处理多个查询并跟踪搜索结果分析的排名位置。我们还将爬行深度设置为顶级变量。让我们将 router.default_handler 移至 paths.py 以匹配项目结构:
@crawler.router.default_handler async def default_handler(context: BeautifulSoupCrawlingContext) -> None: """Default request handler.""" context.log.info(f'Processing {context.request} ...') for item in context.soup.select("div#search div#rso div[data-hveid][lang]"): data = { 'title': item.select_one("h3").get_text(), "url": item.select_one("a").get("href"), "text_widget": item.select_one("div[style*='line']").get_text(), } await context.push_data(data)
我们还可以修改处理程序以添加 query 和 order_no 字段以及基本错误处理:
await context.enqueue_links(selector="div[role='navigation'] td[role='heading']:last-of-type > a")
我们就完成了!
我们的 Google 搜索抓取工具已准备就绪。我们来看看 google_ranked.csv 文件中的结果:
代码存储库可在 GitHub 上获取
如果您正在从事需要数百万个数据点的大型项目,例如本文中有关 Google 排名分析的项目 - 您可能需要一个现成的解决方案。
考虑使用 Apify 团队开发的 Google 搜索结果抓取工具。
它提供了重要的功能,例如:
您可以在 Apify 博客中了解更多信息
在本博客中,我们逐步探索了如何创建收集排名数据的 Google 搜索抓取工具。如何分析此数据集取决于您!
温馨提示,您可以在 GitHub 上找到完整的项目代码。
我想 5 年后我需要写一篇关于“如何从 LLM 的最佳搜索引擎中提取数据”的文章,但我怀疑 5 年后这篇文章仍然具有相关性。
以上是如何使用 Python 抓取 Google 搜索结果的详细内容。更多信息请关注PHP中文网其他相关文章!