首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

使用 Python 实现微信公众号粉丝迁移流程

近日,因公司业务需要,需将原两个公众号合并为一个,即要将其中一个公众号(主要是粉丝)迁移到另一个公众号。按微信规范,同一用户在不同公众号内的 openid 是不同的,我们的业务系统不例外地记录了用户的 openid,因此,涉及到两个公众号的 openid 的转换。幸好,微信公众号平台在账号迁移描述提供了方法和API供调用,详见:

这里使用 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

qcursor = conn.cursor(buffered=True)

wcursor = conn.cursor()

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'

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'

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()

总结

  • 发表于:
  • 原文链接http://kuaibao.qq.com/s/20180125A0Y3HS00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券