Python发送微信模板消息

1、根据appid,secret获取token

2、查找粉丝

3、指定模板及粉丝id发送模板消息

4、链接SqlServer数据库获取消息任务

5、创建定时任务监听消息

python 复制代码
from logging import exception
import time
import pymysql
import datetime;
from utils.http_utils import *;
from model.msg_wx_model import *;
from threading import Timer

appid = "wx*****";
appsecret = "****";   
template_id = '9uWUl0evW9o5Q5KPbZaa4WxpXOsHN9V28vWPG2T**'     #模板id
token = "";


#查找公众号所有的粉丝
def findUser():
    url = f"https://api.weixin.qq.com/cgi-bin/user/get?access_token={token}&next_openid=";
    result = httpGet(url,"");
    print(result);
    for row in result["data"]["openid"]:
        print(row);
        url =  "https://api.weixin.qq.com/cgi-bin/user/info?access_token=" + token + "&openid=" + row;
        jsonText = httpGet(url,"");
        print(jsonText);
        pass;

#指定粉丝发送模板消息
def send(userId, content):

    list = content.split('|');
    first = list[0]
    k1=list[1];
    k2=list[2];
    k3=list[3];
    k4=list[4];
    k5=list[5];
    remark = list[6];

    jsonstr =  "{'first':{ "\
                f"    'value':'{first}',"\
                "    'color':'#173177'"\
                "},"\
                "'keyword1': {"\
                f"    'value':'{k1}',"\
                "    'color':'#173177'"\
                "},"\
                "'keyword2': {"\
                f"    'value':'{k2}',"\
                "    'color':'#173177'"\
                "},"\
                "'keyword3': {"\
                f"    'value':'{k3}',"\
                "    'color':'#173177'"\
                "},"\
                "'keyword4': {"\
                f"    'value':'{k4}',"\
                "    'color':'#173177'"\
                "},"\
                "'keyword5': {"\
                f"    'value':'{k5}',"\
                "    'color':'#173177'"\
                "},"\
                "'remark':{"\
                f"    'value':'{remark}',"\
                "    'color':'#173177'"\
                "}}";

    jsonstr = jsonstr.replace("'", "\"")
    body = "{" + f'"touser":"{userId}", "template_id": "{template_id}", "url":"#", "data":{jsonstr}' + "}";
    data = json.loads(body);

    url = "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + token;
    result = httpPost(url, data , "");
    print(result);

def getToken():  
    print("获取token...")
    url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=" + appid + "&secret=" + appsecret;
    result = httpGet(url,"");
    print(result);
    global token;
    token = result["access_token"];
    #Timer(60*60, getToken).start()

def sendMsg():
    now = datetime.datetime.now()
    ts = now.strftime('%Y-%m-%d %H:%M:%S')
    conn1 = pymysql.connect(host="xx.xx.xx.xx",port=3306,user="root",passwd="xxx",db="sxty_data" )
    cursor1 = conn1.cursor()
    print(ts + " 获取消息任务")
    sql = "select to_user,content,id from msg_wx where state = 0 "
    #print(sql)
    cursor1.execute(sql)
    data1 = cursor1.fetchall()
    #print(data1);
    for row in data1:
        userId = row[0];
        content = row[1];
        msgId = row[2];
        send(userId,content);
        msg = MsgWxModel();
        msg.cursor = cursor1;
        msg.conn = conn1;
        msg.id = msgId;
        msg.state = 1;
        msg.send_date = ts;
        msg.update();
    cursor1.close();
    conn1.close();

#获取token
def job0():
    try:
        getToken();        
    except Exception as reason:
        print(reason)
        pass;

    Timer(60*60, job0).start();       

#发送消息
def job1():

    try:
        sendMsg();        
    except Exception as reason:
        getToken();
        print(reason)

    Timer(5, job1).start();



print("消息服务已启动...")
job0();
job1(); 
  
#findUser();








 
相关推荐
hakesashou2 分钟前
python如何比较字符串
linux·开发语言·python
_.Switch38 分钟前
Python机器学习模型的部署与维护:版本管理、监控与更新策略
开发语言·人工智能·python·算法·机器学习
Hoper.J1 小时前
PyTorch 模型保存与加载的三种常用方式
人工智能·pytorch·python
弱冠少年2 小时前
websockets库使用(基于Python)
开发语言·python·numpy
技术无疆2 小时前
【Python】Streamlit:为数据科学与机器学习打造的简易应用框架
开发语言·人工智能·python·深度学习·神经网络·机器学习·数据挖掘
羊小猪~~2 小时前
机器学习/数据分析--用通俗语言讲解时间序列自回归(AR)模型,并用其预测天气,拟合度98%+
人工智能·python·机器学习·数据挖掘·数据分析·回归·时序数据库
qq_273900232 小时前
解析TMalign文本文件中的转换矩阵
python·生物信息学
阿华的代码王国3 小时前
【JavaEE】——文件IO的应用
开发语言·python
电饭叔4 小时前
《python语言程序设计》2018版第8章19题几何Rectangle2D类(下)-头疼的几何和数学
开发语言·python
程序猿小D4 小时前
第二百六十七节 JPA教程 - JPA查询AND条件示例
java·开发语言·前端·数据库·windows·python·jpa