Python实现每日自动推送URL到百度站长收录

Python实现每日自动推送URL到百度站长收录,第1张

前言

闲来无事,看了下自己写的博客没有一篇文章被百度收录,无奈只好写了一个百度主动提交工具的小脚本,实现每日自动爬取当前博客文章并推送文章URL到百度站长收录,提高下曝光率。

解决

其实百度站长后台也给出了示例:curl推送示例、post推送示例、php推送示例、ruby推送示例一大堆,下面就给大家用Python写一个几句代码就可以实现百度主动提交。

# coding:utf-8
import requests
import re

# 获取网站html数据
def get_html(url):
    try:
        r = requests.get(url+"/archives")
        r.encoding = "utf-8"
        html = r.text
        return html
    except Exception:
        pass

def main(url):
    headers = {
        'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9',
        'Accept-Encoding': 'gzip, deflate, br',
        'Accept-Language': 'zh-CN,zh;q=0.9,en;q=0.8',
        'Cache-Control': 'max-age=0',
        'Connection': 'keep-alive',
        'Cookie': '',
        'Host': 'data.zz.baidu.com',
        'Upgrade-Insecure-Requests': '1',
        'User-Agent': 'curl/7.12.1',
    }
    # 百度提交api
    seo_url = 'http://data.zz.baidu.com/urls?site=121.196.169.103&token={token}'
    html = get_html(url)
    # 正则匹配,筛选出文章链接
    result = re.findall('', html, re.S)
    urls = ""
    for res in result:
        urls += url+res.split('"')[1] + '\n'
    print(urls)
    response = requests.post(seo_url, data=urls.encode(), headers=headers)
    print(response.text)

if __name__ == '__main__':
    url = "http://121.196.169.103"  # 网站链接
    main(url)

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/869258.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-13
下一篇 2022-05-13

发表评论

登录后才能评论

评论列表(0条)

保存