用Python开发一个查询搜索排名的工具,灰常简单

学习交流、寻找源码的小伙伴,请点击【 25个Python实战项目源码

搭建背景

最近工作中需要用上 Google SEOQ(搜索引擎优化),有了解过的朋友们应该都知道SEO必不可少的工作之一就是查询关键词的搜索排名。关键词少的时候可以一个一个去查没什么问题,但是到了后期,一个网站都有几百上千的关键词,你再去一人一个查,至少要花费数小时的时间。

虽然市面上有很多SEO免费或者收费工具,但免费的基本都不能批量查,我看到网上最多也就只能10个10个查询,而目查询速度很慢.

收费的工具如Ahrefs、SEMrush以月为单位收费最低也都要 995/月,当然如果觉得个格合适也可以进行购买,毕竟文些工具的很多功能都很实用。今天我给大家分享的这个排名搜索工具基于python实现,当然肯定是不需要花费任何费用,装python开发环境只即可。

实现步骤

话不多说,上代码

import requests
from bs4 import Beautifulsoup

首先我们导入 requests 和 Beautifulsoup 两个库,requests 用于发送HTTP请求Beautifulsoup 用于解析HTML.

def get_google_rank(keyword, website):
    try:
        url = f"https://www.google.com/search?q={keyword}"
        headers = {'User-Agent': 'Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/114.0.0.0 Mobile Safari/537.36'}
        response = requests.get(url, headers=headers)
        response.raise_for_status()

        soup = BeautifulSoup(response.text, 'html.parser')
        search_results = soup.find_all('div', class_='g')

        for i, result in enumerate(search_results):
            link = result.find('a')['href']
            if website in link:
                return i + 1  # 返回排名(从1开始)
        
        return -1  # 如果未找到网站,返回-1

    except requests.exceptions.RequestException as e:
        print(f"An error occurred: {e}")
        return None

上述代码定义了一个名为 get gogle_rank 的函数,该函数接受两个参数: keyword (关键词)和ebsite (网站域名)。函数的目标是获取指定关键词在谷歌搜索结果中的排名。

在函数内部,首先构建了一个URL,该URL使用指定的关键词进行公歌博索。然后设置了一个User-Agen头部,模拟一个浏览器的请求使用 requests.get 方法发送HTTP请求,获取搜索结果页面的响应。response.raise for_status()用于检查请求是否成功,如果返回的状态码不是200,会抛出一个异常。

接下来,使用 Beautifulsoup 库解析响应的HTML内容,创建一 Beautifulsoup 对象,并使用 html,parser 解析器进行解析。然后通过find_a11 方法查找所有具有class 属性为g的div元素,这些元素包含了搜索结果的信息。

接着使用 enumerate 函数遍历搜索结果列表,并使用 result.find(a"href1 获取每个搜索结果中的链接,如果指定的网站域名出现在链接中,就返回当前的排名 (从1开始计数)

如果循环结束后未找到指定的网站域名,函数返回-1,表示未找到网站。

如果在请求过程中发生异常,会获 requests,exceptions.RequestException 异常,并打印错误消息,然后返回None。

# 示例用法
keywords = [摸鱼小游戏”,是男人就下100层",游戏
website = "haiyong.site'
for keyword in keywords:
6
rank = get google rank(keyword, website)
if rank is not None:
if rank == -1:
print(f“{keyword}没有排名")
10
11
else:
print(f"{keyword}排名第{rank}")

最后是一个示例用法的代码。定义了一个包含多个关键词的列表 keywords 和一个指定的网站域名 website

通过 for 循环遍历关键词列表,调用 get _googe.rank 函数获取每关词在谷歌搜索结果中的排名。如果返回的排名不为 one,则根据排名的值进行条件判断,如果排名为-1,打印关键词没有排名的消息,否则打印关键词的排名信息。

以上就是整段代码的含义和逻辑。该代码实现了获取指定关键词在谷歌搜索结果中的排名,并通过示例展示了如何使用这个函数。

完整代码

import requests
from bs4 import BeautifulSoup

def get_google_rank(keyword, website):
    try:
        url = f"https://www.google.com.hk/search?q={keyword}"
        headers = {'User-Agent': 'Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/114.0.0.0 Mobile Safari/537.36'}
        response = requests.get(url, headers=headers)
        response.raise_for_status()

        soup = BeautifulSoup(response.text, 'html.parser')
        search_results = soup.find_all('div', class_='g')

        for i, result in enumerate(search_results):
            link = result.find('a')['href']
            if website in link:
                return i + 1  # 返回排名(从1开始)
        
        return -1  # 如果未找到网站,返回-1

    except requests.exceptions.RequestException as e:
        print(f"An error occurred: {e}")
        return None

# 示例用法
keywords = ['摸鱼小游戏','是男人就下100层','游戏']
website = 'haiyong.site'

for keyword in keywords:
    rank = get_google_rank(keyword, website)
    if rank is not None:
        if rank == -1:
            print(f"{keyword}没有排名")
        else:
            print(f"{keyword}排名第{rank}")

梯子有点问题,先放个必应上查询的截图吧。



好了,今天的分享就到这结束了,下次再见。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值