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


Posted in Python onJanuary 03, 2018

近日,因公司业务需要,需将原两个公众号合并为一个,即要将其中一个公众号(主要是粉丝)迁移到另一个公众号。按微信规范,同一用户在不同公众号内的 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 实现微信公众号粉丝迁移流程,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Python 相关文章推荐
使用python编写脚本获取手机当前应用apk的信息
Jul 21 Python
使用django-suit为django 1.7 admin后台添加模板
Nov 18 Python
Python3 queue队列模块详细介绍
Jan 05 Python
python+matplotlib实现礼盒柱状图实例代码
Jan 16 Python
Python 查找字符在字符串中的位置实例
May 02 Python
python3中函数参数的四种简单用法
Jul 09 Python
pyqt弹出新对话框,以及关闭对话框获取数据的实例
Jun 18 Python
Python matplotlib生成图片背景透明的示例代码
Aug 30 Python
Python环境管理virtualenv&virtualenvwrapper的配置详解
Jul 01 Python
Python压缩模块zipfile实现原理及用法解析
Aug 14 Python
python实现测试工具(一)——命令行发送get请求
Oct 19 Python
Python爬虫入门案例之回车桌面壁纸网美女图片采集
Oct 16 Python
EM算法的python实现的方法步骤
Jan 02 #Python
Python+树莓派+YOLO打造一款人工智能照相机
Jan 02 #Python
matplotlib绘制动画代码示例
Jan 02 #Python
Python+matplotlib+numpy实现在不同平面的二维条形图
Jan 02 #Python
Python 实现淘宝秒杀的示例代码
Jan 02 #Python
python基于twisted框架编写简单聊天室
Jan 02 #Python
python http接口自动化脚本详解
Jan 02 #Python
You might like
Apache设置虚拟WEB
2006/10/09 PHP
php 结果集的分页实现代码
2009/03/10 PHP
PHP基础教程(php入门基础教程)一些code代码
2013/01/06 PHP
浅谈php错误提示及查错方法
2015/07/14 PHP
Yii框架引入coreseek分页功能示例
2019/02/08 PHP
IE JS编程需注意的内存释放问题
2009/06/23 Javascript
悄悄用脚本检查你访问过哪些网站的代码
2010/12/04 Javascript
自定义jQuery插件方式实现强制对象重绘的方法
2015/03/23 Javascript
实例详解jQuery Mockjax 插件模拟 Ajax 请求
2016/01/12 Javascript
AngularJS 指令详细介绍
2016/07/27 Javascript
基于Javascript实现文件实时加载进度的方法
2016/10/12 Javascript
React组件生命周期详解
2017/07/03 Javascript
详解使用vuex进行菜单管理
2017/12/21 Javascript
vue2.0 computed 计算list循环后累加值的实例
2018/03/07 Javascript
jQuery实现每隔一段时间自动更换样式的方法分析
2018/05/03 jQuery
JavaScript递归函数解“汉诺塔”算法代码解析
2018/07/05 Javascript
如何封装了一个vue移动端下拉加载下一页数据的组件
2019/01/06 Javascript
解决vue语法会有延迟加载显现{{xxx}}的问题
2019/11/14 Javascript
Node.js API详解之 timer模块用法实例分析
2020/05/07 Javascript
js实现QQ邮箱邮件拖拽删除功能
2020/08/27 Javascript
[00:32]2018DOTA2亚洲邀请赛OpTic出场
2018/04/03 DOTA
Python中元组,列表,字典的区别
2017/05/21 Python
Idea安装python显示无SDK问题解决方案
2020/08/12 Python
HTML5触摸事件演化tap事件介绍
2016/03/25 HTML / CSS
椰子猫砂:CatSpot
2018/08/27 全球购物
幼师岗位求职简历的自荐信格式
2013/09/21 职场文书
机修工岗位职责
2013/11/24 职场文书
大学生实习自我鉴定
2013/12/11 职场文书
微笑面对生活演讲稿
2014/05/13 职场文书
教师考核材料
2014/05/21 职场文书
投标人廉洁自律承诺书
2014/05/26 职场文书
历史学专业求职信
2014/06/19 职场文书
房屋租房协议书范本
2014/12/04 职场文书
采购员岗位职责
2015/02/03 职场文书
2016年春季趣味运动会开幕词
2016/03/04 职场文书
私人贷款担保书该怎么写呢?
2019/07/02 职场文书