使用 Python 实现微信公众号粉丝迁移流程
作者:adanz 发布时间:2022-05-10 21:02:07
标签:python,微信公众号,粉丝,迁移
近日,因公司业务需要,需将原两个公众号合并为一个,即要将其中一个公众号(主要是粉丝)迁移到另一个公众号。按微信规范,同一用户在不同公众号内的 openid 是不同的,我们的业务系统不例外地记录了用户的 openid,因此,涉及到两个公众号的 openid 的转换。幸好,微信公众号平台在账号迁移描述提供了方法和API供调用,详见:
http://kf.qq.com/faq/170221aUnmmU170221eUZJNf.html
这里使用 Python 写个程序来完成,简单快捷,主要知识点有:
MySQL connector 使用,也就是 Python DB API 规范
HTTP客户端库 requests 使用
微信公众号平台 API 使用
首先,建立新旧 openid 对照表。
CREATE TABLE change_openidlist(
id BIGINT NOT NULL AUTO_INCREMENT,
ori_openid varchar(100) NOT NULL,
new_openid varchar(100) NOT NULL,
CONSTRAINT crm_change_openidlist_pk PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_general_ci ;
如果没有安装,则需先安装以下类库。
pip install mysql-connector-python
pip install requests
接着,运行下面 python 程序,即可将新旧 openid 对照数据写到 change_openidlist,然后就可以根据这个表的数据去更新其它数据表了。
其它可见注释,不详述,当然不要忘了将 appid 和 secret 替换为自己公众号。
# -*- coding: utf-8 -*-
import requests
import mysql.connector
def handle_data():
try:
token = get_access_token()
#自动提交方式 autocommit=True
conn = mysql.connector.connect(host='127.0.0.1', port='3306', user='user', password='password', database='wx', use_unicode=True,autocommit=True);
qcursor = conn.cursor(buffered=True)
wcursor = conn.cursor()
#旧公众号 openid
qcursor.execute('select openid from wxmembers')
size = 100
while True:
list = qcursor.fetchmany(size)
if not list:
break
changeopenid_list = get_changeopenid_list(list,token)
wcursor.executemany('insert into change_openidlist (ori_openid,new_openid) values (%s, %s)',changeopenid_list)
except mysql.connector.Error as e:
print ('Error : {}'.format(e))
finally:
qcursor.close
wcursor.close()
conn.close
print 'openid handle finished!'
def get_access_token():
new_appid = '00000'
new_secret = '11111'
url = 'https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential' # grant_type为固定值
payload = {'appid': new_appid, 'secret': new_secret}
r = requests.get(url,params = payload)
response = r.json()
return response['access_token']
def get_changeopenid_list(ori_openid_list,token):
new_access_token = token
ori_appid = '33333'
url = 'http://api.weixin.qq.com/cgi-bin/changeopenid?access_token='+ new_access_token
payload = {'to_appid': ori_appid, 'openid_list': ori_openid_list}
r = requests.post(url,json = payload)
response = r.json()
result_list = response['result_list']
openid_list = [[result['ori_openid'],result['new_openid']] for result in result_list if result['err_msg'] == 'ok']
return openid_list
if __name__ == '__main__':
handle_data()
总结
以上所述是小编给大家介绍的使用 Python 实现微信公众号粉丝迁移流程网站的支持!
来源:https://www.jianshu.com/p/d1bf418eac91?utm_source=tuicool&utm_medium=referral


猜你喜欢
- 1 np.arange(),类似于range,通过指定开始值,终值和步长来创建表示等差数列的一维数组,注意该函数和range一样结果不包含终
- 简单实现了一个在函数执行出现异常时自动重试的装饰器,支持控制最多重试次数,每次重试间隔,每次重试间隔时间递增。最新的代码可以访问从githu
- 1. 谈谈Javascript的对象Javascript作为一种弱语言类型的语言,同时也是一种动态类型的语言。在使用Javascript的过
- 一、Tensorlow结构import tensorflow as tfimport numpy as np#创建数据x_data = np
- 本文实例讲述了Python多线程通信queue队列用法。分享给大家供大家参考,具体如下:queue:什么是队列:是一种特殊的结构,类似于列表
- 我就废话不多说了,大家还是直接看代码吧~#!/usr/bin/env python# -*- coding: utf-8 -*-import
- 当用户首次安装MySQL数据库时,总是想修改root的初始化密码,我也是,每次都百度一下,下面主要给出一些操作数据库的常用SQL和一些基本概
- 尽管Python提供了多个消息框已经能够满足大部分正常人的需求,但并不够灵活,所以有的时候不得不自定义消息框。新建窗口消息框的本质是一个窗口
- 基本信息程序包名称:基于.net开发的遵循web标准的个人站点程序包下载开发者主页:www.ceocio.net软件大小:1.84mb安装环
- 在路上发现好多人都喜欢用耳机听小说,同事居然可以一整天的带着一只耳机听小说。小编表示非常的震惊。今天就用 Python 下载听小说 
- 地图这期文章我们一起来看看地图是如何绘制的,如何在地图里面添加数据进行多维度的展示,下面我们一起来感受一下地图的魅力吧!&ldquo
- 先看一下flask-login模块的整体架构基础的信息和全局配置这里就不多说,需要用到再斟酌也可以的。这里也是针对每个模块较为常用的进行解释
- 前言Tenacity是一个 Apache 2.0授权的通用重试库,用 Python 编写,用于简化向几乎所有内容添加重试行为的任务。它起源于
- 油画的实现原理油画简单的理解是带有艺术感的图像,色彩相对于原图要更加鲜艳,但却是失真的。而且对于喜欢欣赏艺术的读者,肯定或多或少关注过油画,
- 1.引入正则模块(Regular Expression)要使用python3中的RE则必须引入 re模块import re #引入正则表达式
- 1. 引言热力图,是一种通过对色块着色来显示数据的统计图表。绘图时,需指定颜色映射的规则。例如,较大的值由较深的颜色表示,较小的值由较浅的颜
- 在之前介绍PyQtGraph的文章中,我们都是一次性的获取数据并将其绘制为图形。然而在很多场景中,我们都需要对实时的数据进行图形化展示,比如
- 这个分页使用的是0游标,也就是Rs.Open Sql,Conn,0,1。但是感觉也快不了多少,10万条数据的分页时间300多豪秒之间。风格A
- 本章将覆盖所有在Python中使用的基本I/O功能。有关更多函数,请参考标准Python文档。打印到屏幕上:产生输出最简单的方法
- 此前带领小组成员主导过一个百万行代码上位机项目的重构工作,分析项目中存在的问题做了些针对性的优化,整个重构工作持续了一年半之久。主要针对以下