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

作者:adanz 时间:2022-05-10 21:02:07 

近日,因公司业务需要,需将原两个公众号合并为一个,即要将其中一个公众号(主要是粉丝)迁移到另一个公众号。按微信规范,同一用户在不同公众号内的 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

标签:python,微信公众号,粉丝,迁移
0
投稿

猜你喜欢

  • python 多线程应用介绍

    2023-07-13 08:04:04
  • python3实现表白神器

    2023-07-27 03:54:01
  • python 自定义异常和异常捕捉的方法

    2022-09-10 12:06:31
  • python中日期和时间格式化输出的方法小结

    2023-07-01 11:39:31
  • PHP封装的一个支持HTML、JS、PHP重定向的多功能跳转函数

    2023-11-19 07:25:14
  • python利用MethodType绑定方法到类示例代码

    2023-08-23 08:07:31
  • python利用pytesseract 实现本地识别图片文字

    2021-03-08 19:20:34
  • OpenLayer基于vue的封装使用教程

    2024-05-11 09:16:22
  • Python学习之异常中的finally使用详解

    2021-09-08 02:21:38
  • 关于大批量数据高效插入方法

    2010-07-31 19:07:00
  • XML教程 WEB页面工具语言XML的定义

    2008-05-29 10:54:00
  • Python实现自动批量修改文件名称

    2023-07-30 04:56:56
  • 使用Django开发简单接口实现文章增删改查

    2023-02-12 22:29:37
  • js表单序列化判断空值的实例

    2024-04-22 13:01:15
  • ASP.Net Core MVC基础系列之中间件

    2024-05-09 09:04:47
  • python 函数进阶之闭包函数

    2021-07-21 03:21:29
  • Python3之读取连接过的网络并定位的方法

    2022-02-20 00:36:43
  • Go语言中的自定义类型你了解吗

    2024-02-06 00:11:36
  • Javascript简单实现可拖动的div

    2013-08-20 11:46:37
  • OpenCV学习方框滤波实现图像处理代码示例

    2023-02-08 17:17:43
  • asp之家 网络编程 m.aspxhome.com