搜索
简帛阁>技术文章>python实现微信小程序的接口自动化_python实现小程序推送页面收录脚本

python实现微信小程序的接口自动化_python实现小程序推送页面收录脚本

当时看到小程序页面收录的时候也是很恍然,一直都没有怎么注意到这个东西,直到加了微信小程序社区的官方群才看到有人提及这个东西,索性点进去看了一下,发现收录页面达到了17万,应该不算太多,属于爬虫自然收录。

也有过人问过我怎么做收录的,真的,就是自然收录,无非是详情页比较重要而已,因为参数的不同收录肯定会增多很多,前提是不要随意的拦截用户登录。当然也和朋友交流过这方面的东西,后面发现收录是周期性的,大概是间隔7天左右会有一次上涨,所以过了几天之后涨了4万达到了21万。

但是他们都是页面推送的收录,我去看了下发现我们的是一个推送收录都没有,然后大概的问了问自己就写了一份推送收录的Python脚本。

废话过多直接上代码吧,如有不足之处还望指教。

import requests

import math

import time

import json

"""

@author: axin

@time:2019/12/14 14:30

@File: smpush.py

"""

# 设置配置信息

appid = "" # 小程序appid

secret = "" # 小程序secret

sn = 990 # 每次推送数量

timer = 5 # 每次睡眠时间

# 获取小程序assess_token

tokenUrl = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={}&secret={}".format(appid, secret)

tokenReq = requests.get(tokenUrl)

tokenResp = tokenReq.json()

token = tokenResp['access_token']

# 拼接推送链接

url = "https://api.weixin.qq.com/wxa/search/wxaapi_submitpages?access_token={}".format(token)

# 获取小程序招工推送列表

postData = {

"access_token": token,

"pages": []

}

#读取所有待推送信息

with open('ids.txt', 'r') as f:

ids = f.read()

ids = ids.split(",") # 切割成数组保存

idsLen = len(ids) # 获取数组长度

maxGroup = math.ceil(idsLen / sn) # 最大的分组数量

group_m = -1

lists = [] # 使用新数组保存

for i in range(idsLen):

if i % sn == 0:

group_m += 1

lists.append([ids[i]])

else:

lists[group_m].append(ids[i])

#分组推送

sign = 0 # 标记当前推送条数

for item in lists:

arrData = [] # 声明或重置待提交数组

for i in item:

data = {

"path": "pages/detail/info/info",

"query": "id=" + i

}

arrData.append(data)

postData['pages'] = arrData

onceReq = requests.post(url, json.dumps(postData))

onceRes = onceReq.json()

signStart = sign * sn

signEnd = (sign * sn) + sn

if onceRes['errcode'] == 0:

print("当前推送第{} - {} 条:成功!最后一条数据为:{}".format(signStart, signEnd, arrData[-1]))

elif onceRes['errcode'] == 47006:

print("当前推送第{} - {} 条:失败!返回状态码:{},最后一条数据为:{}, 当日推送已达到最大上限!".format(signStart, signEnd, onceRes['errcode'], arrData[-1]))

break

else:

print("当前推送第{} - {} 条:失败!返回状态码:{},最后一条数据为:{}".format(signStart, signEnd, onceRes['errcode'], arrData[-1]))

sign += 1

time.sleep(timer) # 设置睡眠时间

还有一个参数文本,由于id过多就将id导入了一个txt,然后读取之后用","进行了一次分割。

2020042009152814.png

感谢@克隆:sheep:多利建议改了Python的format以及下掉eval

2020042009152815.png

到此这篇关于python实现小程序推送页面收录脚本的文章就介绍到这了,更多相关python推送收录内容请搜索python博客以前的文章或继续浏览下面的相关文章希望大家以后多多支持python博客!

当时看到程序页面收录时候也是很恍然,一直都没有怎么注意到这个东西,直到加了微信小程序社区官方群才看到有人提及这个东西,索性点进去看了一下,发现收录页面达到了17万,应该不算太多,属于爬虫自然收录
程序搜索推送接口:developersweixinqqcom/miniprogram…程序获取assess_token:developersweixinqqcom/miniprogram…当时看
程序搜索推送接口:developers.weixin.qq.com/miniprogram…程序获取assess_token:developers.weixin.qq.com/miniprogra
微信现已开放程序内搜索,开发者可以通过sitemapjson配置,或者管理后台页面收录开关来配置其程序页面是否允许微信索引。当开发者允许微信索引时,微信会通过爬虫形式,为程序页面内容建立索引
1、杨辉三角形Python实现:1/\11/\/\121/\/\/\1331/\/\/\/\14641/\/\/\/\/\15101051杨辉三角形deftriangel(n):L[1]定义一个lis
wxml文件:<formbind:submittestSubmitreportsubmittruehidden{<!>{emptyprompt}}><buttonform
程序可以通过官方提供登录邓丽来获取用户身份标示,具体文档可以参考官方文档,通过流程时序可以看到,对于需要和前端配合服务端开发,主要实现就是通过程序提供code换取用户openid和s
importxlrdimportrandombookxlrdopen_workbook('student_namexls')sheetbooksheet_by_index(0)name_sheetsh
文章有点标题党,单纯从技术上来实现无限推送暂时是不可能。为什么不可能?推送程序官方叫法是模板消息。先来看看官方对他下发条件说明:1支付当用户在程序内完成过支付行为,可允许开发者向用户在7
具体代码如下:(推荐教程:python基础教程)importtimefromurllibimportrequest文章URLurl_list['108668971','108620289','10