您好,登錄后才能下訂單哦!
使用 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 怎么遷移微信公眾號粉絲問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。