前言

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

解决

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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
# 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('<li.*?href=("/archives/.*?")>', 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)

©2018 - Felicx 使用 Stellar 创建
总访问 113701 次 | 本页访问 326
共发表 86 篇Blog · 总计 128.7k 字