近日,因公司业务需要,需将原两个公众号合并为一个,即要将其中一个公众号(主要是粉丝)迁移到另一个公众号。按微信规范,同一用户在不同公众号内的 openid 是不同的,我们的业务系统不例外地记录了用户的 openid,因此,涉及到两个公众号的 openid 的转换。幸好,微信公众号平台在账号迁移描述提供了方法和API供调用,详见:
http://kf.qq.com/faq/170221aUnmmU170221eUZJNf.html
这里使用 Python 写个程序来完成,简单快捷,主要知识点有:
首先,建立新旧 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 实现微信公众号粉丝迁移流程,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!
微信粉丝 可随时更新粉丝列表,也可搜索 当用户关注到商城公众号后,系统会形成粉丝列表
本SDK支持微信公众号以及企业号的上行消息及OAuth接口。本文档及SDK假设使用者已经具备微信公众号开发的基础知识,及有能力通过微信公众号、企业号的文档来查找相关的接口详情。 1. 安装 pip install wechat 源码安装 git clone git@github.com:jeffkit/wechat.gitcd wechatpython setup.py install 对于微信用
方案1:将公众号授权给智齿 接入效果 授权过程 授权微信公众号给智齿需要智齿客服管理员和微信公众号管理员共同参与,具体步骤如下: 第一步:智齿客服管理员进入智齿管理后台「设置-支持渠道-微信」,点击「绑定公众号」进入授权页,可见微信授权二维码 <微信公众号授权扫码页-电脑端> 第二步:由企业微信公众号管理员在微信端扫码、确认勾选授权哪些权限集给智齿并点击确认授权,完成授权后即算部署完成 <
微信公众号 微信公众号扫码授权以后,用户发往公众号的消息会转发给机器人,机器人会自动回复消息给公众号用户,同一个微信公众号同时只能绑定一个机器人,如果绑定了新的机器人,之前绑定的机器人会解除绑定。 注:微信公众号渠道接入后,仅支持微信文字,语音两种方式问答,用户在微信聊天框输入语音后,客服系统自动识别语音成文字进行答复。 只需三步接入微信公众号,自动回答公众号上的用户问题 1. 创建机器人 注册登
本文向大家介绍Python版实现微信公众号扫码登陆,包括了Python版实现微信公众号扫码登陆的使用技巧和注意事项,需要的朋友参考一下 基于python 实现公众扫码登陆 前提 申请公众号服务,配置相关信息,并在相关平台进行配置,就这么多东西 实现逻辑,使用临时临时二维码,带参数的二维码扫码登陆 流程,用户已经扫码关注,在登陆页面直接扫码登陆, 用户未关注,则需要点击关注后,直接登录, 我们使用带
本章将介绍如何在您认证的微信公众号、订阅号中集成小能在线咨询功能 微信对接准备 微信对接模式介绍 微信授权模式 微信极速模式 微信开发模式-真Token方案 微信开发模式-假Token方案