吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 4067|回复: 6
收起左侧

[Python 原创] 【开源】自己写的微信每日图文推送源码

[复制链接]
vanmay 发表于 2022-9-20 12:13
本帖最后由 vanmay 于 2022-9-20 17:52 编辑

前言

项目介绍及效果展示

请看我的另一篇帖子→[Python] 【开源项目】DailyInfo——基于企业微信接口的每日图文推送(手机微信也能接收)

开源地址

Github    Gitee
包含所有源码、详细介绍与手把手部署教程,全部开源
欢迎前往Star、Fork、PR,感谢感谢!

使用方法

完整的Dailyinfo部署方法请前往上述开源地址查看

腾讯云云函数

把下面源码放在腾讯云云函数的src文件夹里,分别命名为 index.py 和 config.py,完善config.py里面的配置信息,点击部署后测试

服务器

把下面源码放在同一个文件夹中,分别命名为 index.py 和 config.py,完善config.py里面的配置信息,文件夹内打开终端,执行python3 index.py

源码

主函数 index.py

'''
Author: thund1r thuncoder@foxmail.com
Date: 2022-08-22 15:41:27
LastEditTime: 2022-09-16 16:12:09
Description: 主函数

Copyright (c) 2022 by thund1r thuncoder@foxmail.com, All Rights Reserved. 
'''
# -*- coding: utf8 -*-
import os
import requests
from datetime import datetime, date, timedelta
import re
import config
import random
from zhdate import ZhDate

nowdatetime = (datetime.utcnow() + timedelta(hours=8))
corpid = config.get("corpid")
corpsecret = config.get("corpsecret")
agentid = config.get("agentid")
qweather = config.get("qweather")
link = config.get("link")
title = config.get("title")
content = config.get("content")
call = config.get("call")
pic = config.get("pic")
pic_type = config.get("pictype")
tian = config.get("tian")
msg_type = str(config.get("msgtype")) if config.get("msgtype") else "1"
wea_city_list = config.get_list("city")
target_day_list = config.get_list("targetday")
target_name_list = config.get_list("targetname")
begin_day_list = config.get_list("beginday")
begin_name_list = config.get_list("beginname")
yq_city_list = config.get_list("yqcity")

# 获取标题数据
def get_my_title():
    my_title = title
    if my_title:
        return my_title
    else:
        # 需要通过接口获取动态内容时,请替换下一行内容
        return None

# 获取自定义第一段内容数据
def get_my_content():
    content_list = []
    tian_key = tian
    today_tip = get_today()["today_tip"]
    content_list.append("\n"+today_tip)
    my_content = content
    if my_content:
        content_list.append(my_content)
    if tian_key:
        chp_tip = get_chp(tian_key)
        if chp_tip:
            content_list.append(chp_tip)
    # 加入其他数据作为第一段在这里接收
    return '\n'.join(content_list)

# # 获取天行彩虹屁
def get_chp(tian_key):
    try:
        chp_url = f"http://api.tianapi.com/caihongpi/index?key={tian_key}"
        chp_res = requests.get(chp_url).json()
        chp_tip = "🌈 " + chp_res["newslist"][0]["content"]
        return chp_tip
    except Exception as e:
        print("获取彩虹屁数据出错,请检查是否正确填写天行Key,是否申请彩虹屁接口:", e)
        return None

# 获取自定义头图数据
def get_my_pic():
    my_pic = pic
    if my_pic:
        return my_pic
    else:
        return None

# 获取随机图片链接数据
# 来自搏天API:https://api.btstu.cn/
def get_random_pic():
    lx = pic_type if pic_type else "fengjing"
    try:
        pic_url = f"https://api.btstu.cn/sjbz/api.php?format=json&lx={lx}"
        r = requests.get(pic_url).json()
        return r["imgurl"]
    except Exception as e:
        print("获取随机图片数据出错:", e)
        return None

# 获取金山词霸数据
def get_ciba():
    try:
        ciba_url = "http://open.iciba.com/dsapi/"
        r = requests.get(ciba_url).json()
        ciba_en = r["content"]
        ciba_zh = r["note"]
        ciba_pic = r["fenxiang_img"]
        ciba_tip = "🔤 "+ciba_en+"\n"+"🀄️ "+ciba_zh
        return {
            "ciba_tip": ciba_tip,
            "ciba_pic": ciba_pic
        }
    except Exception as e:
        print("获取金山词霸数据出错:", e)
        return None

# 获取XXX自定义图片与文字函数可以放置在此
# 参考上方获取金山词霸数据get_ciba()代码编写与位置放置,注意缩进
# 务必要在下方handle_message()里编写加入自定义数据的代码
# 具体内容请参考并使用template.py进行测试
# def get_XXX():
#     try:
#         XXX_url = "https://XXXX.XXX"
#         XXX_res = requests.get(XXX_url).json()
#         print("获取XXX自定义图片与文字json数据:", XXX_res)
#         XXX_item0 = XXX_res["键名"][n]["需要的数据键名"]
#         XXX_item1 = XXX_res["键名"][n]["需要的数据键名"]
#         XXX_pic = XXX_res["键名"][n]["需要的数据键名"]
#         XXX_tip = "✒️ " + XXX_item0 + "\n" + "🗓️ " + XXX_item1
#         res = {
#             # 没有图片就删除下面这一句
#             "XXX_pic": XXX_pic,
#             "XXX_tip": XXX_tip
#         }
#         print("获取XXX数据:", res)
#         return res
#     except Exception as e:
#         print("获取XXX数据出错:", e)
#         return None

# 获取今日日期数据
def get_today():
    ndt = nowdatetime
    d = ndt.strftime("%Y{y}%m{m}%d{d}").format(y='年', m='月', d='日')
    w = int(ndt.strftime("%w"))
    week_list = ["星期日", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六"]
    today_date = f"{d} {week_list[w]} "
    now_time = ndt.strftime("%H:%M:%S")
    time_tip = ""
    if "00:00:00" <= now_time < "06:00:00":
        time_tip = "凌晨好"
    elif "06:00:00" <= now_time < "09:00:00":
        time_tip = "早上好"
    elif "09:00:00" <= now_time < "12:00:00":
        time_tip = "上午好"
    elif "12:00:00" <= now_time < "13:00:00":
        time_tip = "中午好"
    elif "13:00:00" <= now_time < "18:00:00":
        time_tip = "下午好"
    elif "18:00:00" <= now_time < "23:59:59":
        time_tip = "晚上好"
    time_tip = f"{time_tip} ~ {get_emoticon()}"
    today_tip = call + time_tip if call else time_tip
    return {
        "today_date": today_date,
        "today_tip": today_tip
    }

# 获取随机颜文字
def get_emoticon():
    emoticon_list = ["( ̄▽ ̄)~*", "(~ ̄▽ ̄)~", "︿( ̄︶ ̄)︿", "~( ̄▽ ̄)~*", "(o゚▽゚)o", "ヾ(✿゚▽゚)ノ", "٩(๑❛ᴗ❛๑)۶", "ヾ(◍°∇°◍)ノ゙", "ヾ(๑╹◡╹)ノ", "(๑′ㅂ`๑)", "(*′゚∀゚`)ノ", "(′▽`)ノ", "ヾ(●′∀`●)",
                     "(。◕ˇ∀ˇ◕)", "(≖ᴗ≖)✧", "(◕ᴗ◕✿)", "(❁′◡`❁)*✲゚*", "(๑ˉ∀ˉ๑)", "(*′・v・)", "(づ。◕ᴗᴗ◕。)づ", "o(* ̄▽ ̄*)o", "(`・ω・′)", "( • ̀ω•́ )✧", "ヾ(=・ω・=)o", "( ̄3 ̄)a", "(灬°ω°灬)", "ヾ(•ω•`。)", "。◕ᴗ◕。"]
    return random.choice(emoticon_list)

# 获取bing每日壁纸数据
def get_bing():
    try:
        bing_url = "https://cn.bing.com/HPImageArchive.aspx?format=js&idx=0&n=1"
        res = requests.get(bing_url).json()
        bing_pic = "https://cn.bing.com/" + res["images"][0]["url"]
        bing_title = res["images"][0]["title"]
        bing_content = re.sub("\\(.*?\\)", "", res["images"][0]["copyright"])
        bing_tip = f"{bing_title}——{bing_content}"
        return {
            "bing_pic": bing_pic,
            "bing_tip": bing_tip
        }
    except Exception as e:
        print("获取必应数据出错:", e)
        return None

# 获取和风天气数据
def get_weather(city_name):
    try:
        city_id = None
        weather_tip = None
        city = city_name.split("-")[0]
        county = city_name.split("-")[1]
        city_url = f"https://geoapi.qweather.com/v2/city/lookup?&adm={city}&key={qweather}&location={county}"
        city_json = requests.get(city_url).json()
        city_code = city_json["code"]
        if city_code.__eq__("200"):
            city_id = city_json["location"][0]["id"]
        else:
            print(
                f"没有找到{city_name}这个地方,请检查city值是否正确,格式是否为 省/市-市/区/县 ,例如 成都-双流&&江苏-江宁")
        if city_id:
            # 获取逐天天气预报,有很多天气类信息,可以根据自己需要进行获取和拼接
            # 具体请参考和风天气逐天天气预报开发文档https://dev.qweather.com/docs/api/weather/weather-daily-forecast/
            weather_url = f"https://devapi.qweather.com/v7/weather/3d?key={qweather}&location={city_id}"
            weather_json = requests.get(weather_url).json()
            weather_code = weather_json["code"]
            weather_list = []
            if weather_code.__eq__("200"):
                temp = weather_json["daily"][0]
                textDay = temp["textDay"]
                tempMin = temp["tempMin"]
                tempMax = temp["tempMax"]
                weather_icon = get_weather_icon(textDay)
                weather_tip = weather_icon+" "+county+textDay+","+tempMin+"~"+tempMax+"℃"
                weather_list.append(weather_tip)
            # 获取穿衣指数。生活指数有很多信息,可以根据自己需要进行获取和拼接
            # 具体请参考和风天气生活指数开发文档https://dev.qweather.com/docs/api/indices/
            life_url = f"https://devapi.qweather.com/v7/indices/1d?type=3&location={city_id}&key={qweather}"
            life_json = requests.get(life_url).json()
            life_code = life_json["code"]
            if life_code.__eq__("200"):
                life_tip = "👔 " + life_json["daily"][0]["text"]
                weather_list.append(life_tip)
            # 需要和风天气其他接口的信息请参考以上代码格式进行获取和添加,所有开发文档https://dev.qweather.com/docs/api/

            weather_tip = '\n'.join(weather_list)
        else:
            print(
                f"获取{city_name}ID失败,请检查qweather、city值是否正确,city格式是否为 省/市-市/区/县 ,例如 四川-成都&&江苏-江宁")
        return weather_tip
    except Exception as e:
        print(f"获取{city_name}和风天气数据出错:", e)
        return None

# 获取天气icon
def get_weather_icon(text):
    weather_icon = "🌤️"
    weather_icon_list = ["☀️",  "☁️", "⛅️",
                         "☃️", "⛈️", "🏜️", "🏜️", "🌫️", "🌫️", "🌪️", "🌧️"]
    weather_type = ["晴", "阴", "云", "雪", "雷", "沙", "尘", "雾", "霾", "风", "雨"]
    for index, item in enumerate(weather_type):
        if re.search(item, text):
            weather_icon = weather_icon_list[index]
            break
    return weather_icon

# 获取所有天气数据
def get_map_weather(city_name):
    if qweather and city_name:
        map_weather_tip = None
        weather_list = list(map(get_weather, city_name))
        weather_list = list(filter(None, weather_list))
        if weather_list:
            map_weather_tip = "\n".join(weather_list)
        return map_weather_tip
    else:
        print("和风天气秘钥qweather或城市city配置缺失")
        return None

# 计算每年纪念日
def get_remain(target_day, target_name):
    ndt = nowdatetime
    today = date(ndt.year, ndt.month, ndt.day)
    this_year = datetime.now().year
    target_day_year = target_day.split("-")[0]
    if target_day_year[0] == "n":
        lunar_mouth = int(target_day.split("-")[1])
        lunar_day = int(target_day.split("-")[2])
        this_date = ZhDate(this_year, lunar_mouth,
                           lunar_day).to_datetime().date()
    else:
        solar_month = int(target_day.split("-")[1])
        solar_day = int(target_day.split("-")[2])
        this_date = date(this_year, solar_month, solar_day)
    if today == this_date:
        remain_day = 0
        remain_tip = f"🌟 {target_name}就是今天啦!"
    elif today > this_date:
        if target_day_year[0] == "n":
            lunar_next_date = ZhDate(
                (this_year + 1), lunar_mouth, lunar_day).to_datetime().date()
            next_date = date(
                (this_year + 1), lunar_next_date.month, lunar_next_date.day)
        else:
            next_date = date(
                (this_year + 1), solar_month, solar_day)
        remain_day = int(str(next_date.__sub__(today)).split(" ")[0])
        remain_tip = f"🗓️ 距离{target_name}还有 {remain_day} 天"
    else:
        next_date = this_date
        remain_day = int(str(next_date.__sub__(today)).split(" ")[0])
        remain_tip = f"🗓️ 距离{target_name}还有 {remain_day} 天"
    return (remain_tip, remain_day)

# 计算某天间隔天数
def get_duration(begin_day, begin_name):
    ndt = nowdatetime
    today = date(ndt.year, ndt.month, ndt.day)
    begin_day_year = begin_day.split("-")[0]
    if begin_day_year[0] == "n":
        lunar_year = int(begin_day_year[1:])
        lunar_mouth = int(begin_day.split("-")[1])
        lunar_day = int(begin_day.split("-")[2])
        begin_date = ZhDate(lunar_year, lunar_mouth,
                            lunar_day).to_datetime().date()
    else:
        solar_year = int(begin_day.split("-")[0])
        solar_month = int(begin_day.split("-")[1])
        solar_day = int(begin_day.split("-")[2])
        begin_date = date(solar_year, solar_month, solar_day)
    if today == begin_date:
        duration_day = 0
        duration_tip = f"🌟 {begin_name}就是今天啦!"
    elif today > begin_date:
        duration_day = int(str(today.__sub__(begin_date)).split(" ")[0])
        duration_tip = f"🗓️ {begin_name}已经 {duration_day} 天"
    else:
        duration_day = int(str(begin_date.__sub__(today)).split(" ")[0])
        duration_tip = f"🗓️ 距离{begin_name}还有 {duration_day} 天"
    return (duration_tip, duration_day)

# 获取第一个元素
def get_elemzero(elem):
    return elem[0]

# 获取第二个元素
def get_elemone(elem):
    return elem[1]

# 获取所有日期提醒数据
def get_days_tip():
    days_list = []
    days_tip = ""
    target_res = ""
    if target_day_list or target_name_list:
        if len(target_day_list) == len(target_name_list):
            try:
                target_res = list(
                    map(get_remain, target_day_list, target_name_list))
                days_list.extend(target_res)
            except Exception as e:
                print("获取纪念日数据出错,请检查纪念日targetname与targetday填写是否正确", e)
                return None
        else:
            print("获取纪念日数据出错,请检查纪念日targetname与targetday数量是否相等")
    else:
        print("未配置纪念日")
    begin_res = ""
    if begin_day_list or begin_name_list:
        if len(begin_day_list) == len(begin_name_list):
            try:
                begin_res = list(
                    map(get_duration, begin_day_list, begin_name_list))
                days_list.extend(begin_res)
            except Exception as e:
                print("获取单日数据出错,请检查单日beginname与beginday填写是否正确", e)
                return None
        else:
            print("获取单日数据出错,检查单日beginname与beginday数量是否相等")
    else:
        print("未配置单日")
    days_list = list(filter(None, days_list))
    if days_list:
        days_list.sort(key=get_elemone)
        res = list(map(get_elemzero, days_list))
        days_tip = "\n".join(res)
    return days_tip

# 获取ONE一个图文数据
def get_one():
    try:
        one_url = "https://apier.youngam.cn/essay/one"
        r = requests.get(one_url).json()['dataList'][0]
        one_id = "VOL."+r['id']
        one_pic = r['src']
        one_tip = f"✒️ {one_id} {r['text']}"
        return {
            "one_pic": one_pic,
            "one_tip": one_tip
        }
    except Exception as e:
        print("获取ONE一个图文数据出错:", e)
        return None

# 获取城市疫情数据
def get_yq(city_name):
    try:
        res = requests.get(
            f'https://covid.myquark.cn/quark/covid/data/index_data?format=json&method=Huoshenshan.ncov2022&city={city_name}').json()['data']
        if len(res['cityData']) == 0:
            res['cityData'] = res['provinceData']
        yq_res_list = [
            {"desc": "🤒 新增确诊/无症状",
                "detail": str(res['cityData']["sure_new_loc"])+"/" + str(res['cityData']["sure_new_hid"])},
            {"desc": "😷 现有确诊",
                "detail": res['cityData']["present"]},
            {"desc": "⛔️ 高/中风险区",
                "detail": str(res['cityData']["danger"]["1"]) + "/" + str(res['cityData']["danger"]["2"])}
        ]
        yq_tip_list = []
        yq_tip_list.append(f'🏥 {city_name}疫情({(res["time"][4:])})')
        for item in yq_res_list:
            yq_tip_list.append(item['desc'] + ":" + str(item['detail']))
        yq_tip = '\n'.join(yq_tip_list)
        return yq_tip
    except Exception as e:
        print("获取疫情数据失败:", e)
        return None

# 获取所有疫情数据

def get_map_yq(city_name):
    if city_name:
        map_yq_tip = None
        yq_list = list(map(get_yq, city_name))
        yq_list = list(filter(None, yq_list))
        if yq_list:
            map_yq_tip = "\n".join(yq_list)
        return map_yq_tip
    else:
        print("没有填写疫情数据城市")
        return None

# 处理多图文内容
def handle_multi(out_title, inner_title, content, pic, art_link):
    if msg_type != "2":
        return None
    if out_title or inner_title or content or pic or art_link:
        own_link = link
        if out_title is None:
            if content:
                out_title = content
            elif inner_title:
                out_title = inner_title
            else:
                out_title = "查看图片"
        picurl = pic or get_random_pic()
        inner_title = inner_title.replace("\n", "\\n") if inner_title else None
        content = content.replace("\n", "\\n") if content else None
        url = art_link or f"{own_link}?t={inner_title}&p={picurl}&c={content}"
        return {
            "title": out_title,
            "url": url,
            "picurl": picurl
        }
    else:
        print("多图文没有任何内容,生成链接失败")
        return None

# 处理所有信息
def handle_message():
    info_list = []
    multi_list = []
    lx = pic_type
    own_link = link
    own_pic = get_my_pic()
    own_title = get_my_title()
    own_content = get_my_content()
    info_list.append(own_content)

    # 接受今日日期数据
    today_data = get_today()
    today_date = today_data["today_date"]

    # 接收必应数据
    bing_pic = ""
    bing_tip = ""
    bing_flag = 1
    bing_data = get_bing()
    if bing_data:
        bing_pic = bing_data["bing_pic"]
        bing_tip = bing_data["bing_tip"]

    art_title = today_date
    art_content = own_content
    art_pic = get_random_pic()
    if own_pic or own_title or lx:
        if own_pic:
            art_pic = own_pic
        if own_title:
            art_title += "\n" + own_title
        multi_list.append(handle_multi(
            art_title, art_title, art_content, art_pic, None))

    elif bing_tip and bing_pic:
        art_pic = bing_pic
        art_title = art_title + "\n" + bing_tip
        multi_list.append(handle_multi(
            art_title, art_title, art_content, art_pic, None))
        bing_flag = 0
    art_pic = art_pic if lx != "none" else None

    # 下面加入各数据的顺序即在卡片上显示的顺序
    # 不需要的数据请在下面对应的段落操作
    # 不需要出现在单图文的请删除info_list.append(XXX)
    # 不需要出现在多图文的请删除multi_list.append(XXX)
    # 都不要的数据直接删除一整段即可

    # 加入天气数据
    weather_tip = get_map_weather(wea_city_list)
    if weather_tip:
        info_list.append(weather_tip)
        multi_list.append(handle_multi(
            weather_tip, "Weather", weather_tip, None, None))

    # 加入日期提醒数据
    days_tip = get_days_tip()
    if days_tip:
        info_list.append(days_tip)
        multi_list.append(handle_multi(
            days_tip, "Days", days_tip, None, None))

    # 加入疫情数据
    yq_tip = get_map_yq(yq_city_list)
    if yq_tip:
        info_list.append(yq_tip)
        multi_list.append(handle_multi(
            yq_tip, "COVID-19", yq_tip, None, None))

    # 加入bing数据
    if bing_flag and bing_pic and bing_tip:
        multi_list.append(handle_multi(
            "🖼️ "+bing_tip, "Bing", "🖼️ "+bing_tip, bing_pic, None))

    # 加入金山词霸数据
    ciba_data = get_ciba()
    if ciba_data:
        ciba_tip = ciba_data["ciba_tip"]
        ciba_pic = ciba_data["ciba_pic"]
        info_list.append(ciba_tip)
        multi_list.append(handle_multi(
            ciba_tip, "iCiba", ciba_tip, ciba_pic, None))

    # 加入ONE一个数据
    one_data = get_one()
    if one_data:
        one_tip = one_data["one_tip"]
        one_pic = one_data["one_pic"]
        info_list.append(one_tip)
        multi_list.append(handle_multi(
            one_tip, "ONE·一个", one_tip, one_pic, None))

    # 加入自定义XXX数据可以放置在下方,务必注意缩进,格式参考上方的加入ONE一个数据
    # # 加入XXX图文数据
    # XXX_data = get_XXX()
    # if XXX_data:
    #     XXX_tip = XXX_data["XXX_tip"]
    #     # 没有pic就删除下面这一句
    #     XXX_pic = XXX_data["XXX_pic"]
    #     # 单图文添加数据,不需要就删除下面这一句
    #     info_list.append(XXX_tip)
    #     # 多图文添加数据,不需要就删除下面这一整句
    #     multi_list.append(handle_multi(
    #         out_title, inner_title, content, pic, link))
    #     # out_title多图文卡片标题, inner_title多图文展示页内标题, content多图文内容, pic多图文头图, link自定义跳转链接
    #     # 没有的参数就填None,不能五个参数都没有

    # 处理文本格式
    info_content = "\n\n".join(info_list)
    info_detail = info_content.replace("\n", "\\n")
    page_title = art_title.replace("\n", "\\n")
    page_detail = info_detail
    page_pic = art_pic
    art_url = f"{own_link}?t={page_title}&p={page_pic}&c={page_detail}"

    # 封装数据
    article = [{
        "title": art_title,
        "description": info_content,
        "url": art_url,
        "picurl": art_pic
    }]

    if msg_type == "2":
        article = list(filter(None, multi_list))
    msg = {
        "touser": "@all",
        "toparty": "",
        "totag": "",
        "msgtype": "news",
        "agentid": agentid,
        "news": {
            "articles": article
        },
        "enable_id_trans": 0,
        "enable_duplicate_check": 0,
        "duplicate_check_interval": 1800
    }
    return msg

# 获取调用接口凭证
def get_token(corpid, corpsecret):
    url = "https://qyapi.weixin.qq.com/cgi-bin/gettoken"
    values = {"corpid": corpid, "corpsecret": corpsecret}
    res = requests.get(url, params=values).json()
    if res["errcode"] == 0:
        return res["access_token"]
    print(
        f"企业微信access_token获取失败: {str(res)} 请检查corpid、corpsecret、agentid是否正确填写,是否有多余空格")

    return None

# 处理图文详情页
def handle_html(url_data):
    with open(os.path.join(os.path.dirname(__file__), "show.html"), 'r', encoding='utf-8') as f:
        html = f.read()
    p = url_data.get("p")
    t = url_data.get("t")
    c = url_data.get("c")
    if p and p != "none" and p != "None":
        html = html.replace(".pic{display:none}", "").replace("<&p&>", p)
    if t and t != "none" and t != "None":
        t = t.replace("\\n", "<br/>")
        html = html.replace(".title{display:none}", "").replace("<&t&>", t)
    if c and c != "none" and c != "None":
        c = c.replace("\\n", "<br/>")
        html = html.replace(".content{display:none}", "").replace("<&c&>", c)
    return html

# 主函数
def main():
    if corpid and corpsecret and agentid:
        data = handle_message()
        token = get_token(corpid, corpsecret)
        if token is None:
            return 0
        url = f"https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token={token}"
        res = requests.post(url, json=data).json()
        if res["errcode"] == 0:
            print("企业微信消息发送成功")
            return 1
        else:
            print(f"企业微信消息发送失败: {str(res)}")
            return 0
    else:
        print("企业微信配置缺失,请检查corpid、corpsecret、agentid是否配置,单词拼写是否正确")
        return 0

# 腾讯云入口函数
def main_handler(event, context):
    url_data = event.get("queryString")
    if url_data:
        html = handle_html(url_data)
        return {
            "isBase64Encoded": False,
            "statusCode": 200,
            "headers": {"Content-Type": "text/html"},
            "body": html
        }
    else:
        res = main()
        if res:
            return {
                "isBase64Encoded": False,
                "statusCode": 200,
                "headers": {"Content-Type": "text/html"},
                "body": '{"code":"200","message":"企业微信消息发送成功"}'
            }
        else:
            return {
                "isBase64Encoded": False,
                "statusCode": 404,
                "headers": {"Content-Type": "text/html"},
                "body": '{"code":"404","message":"企业微信消息发送失败"}'
            }

# 其他云函数入口
def handler(event, context):
    main()

# 本地运行入口
if __name__ == "__main__":
    main()

配置函数 config.py

'''
Author: thund1r thuncoder@foxmail.com
Date: 2022-08-23 09:36:39
LastEditTime: 2022-09-16 16:14:18
Description: 配置函数

Copyright (c) 2022 by thund1r thuncoder@foxmail.com, All Rights Reserved. 
'''
# -*- coding: utf8 -*-
import os
SYS_CONFIG = {
    # 企业微信企业ID,必填
    "corpid": "",

    # 企业微信应用Secret,必填
    "corpsecret": "",

    # 企业微信AgentId,必填
    "agentid": "",

    # 和风天气Key,非必填
    "qweather": "",

    # 天气预报地址,非必填
    # 格式:省/市-市/县/区,多地址以&&分隔
    # 例如:四川-成都&&江苏-江宁
    "city": "",

    # 纪念日名称,非必填
    # 每年都有的日子,多日期以&&分隔
    # 例如:某某某的生日&&结婚纪念日
    "targetname": "",

    # 纪念日日期,非必填
    # 公历格式20XX-XX-XX,农历年份前加n
    # 多日期以&&分隔,注意与名称对应
    # 例如:n2020-08-11&&2021-08-26
    "targetday": "",

    # 单日项目名称,非必填
    # 只有某一年有的日子,多日期以&&分隔
    # 例如:跟XX在一起&&某某某出生
    "beginname": "",

    # 单日日期,非必填
    # 公历格式20XX-XX-XX,农历年份前加n
    # 多日期以&&分隔,注意与名称对应
    # 例如:n2020-08-11&&2021-08-26
    "beginday": "",

    # 图文类型,非必填
    # 1为单图文,2为多图文,默认单图文
    "msgtype": "",

    # 自定义头图链接,非必填
    # 务必以http:// 或 https:// 开头
    "pic": "",

    # 随机图片类型,非必填
    # 默认fengjing
    # 可选项meizi、dongman、fengjing、suiji、none
    # 分别是妹子、动漫、风景、随机、单图文不显示图片
    "pictype": "",

    # 自定义标题,非必填
    # 例如:今天的推送来啦!
    "title": "",

    # 自定义第一段内容,非必填
    # 例如:记得喝水水哦~
    "content": "",

    # 自定义称呼,非必填
    # 例如:宝贝~
    "call": "",

    # 需要疫情数据的城市名称,非必填
    # 只能是市级,多城市以&&分隔
    # 例如:成都&&南京
    "yqcity": "",

    # 天行数据APIKEY,非必填
    # 需要彩虹屁等数据时填写
    "tian": "",

    # 图文详情页链接,非必填
    # 完成教程 配置页面 后再填写
    # 腾讯云函数用户填写API网关触发网关网址
    # 服务器用户请自行搭建Diary,填写已备案域名:端口号/show
    # 务必以http:// 或 https:// 开头
    "link": ""
}

# 获取配置
def get(key: str):
    value = os.getenv(key.upper())
    if value is None:
        key = key.lower()
        value = os.getenv(key)
    if value is None and key in SYS_CONFIG:
        value = SYS_CONFIG[key]
    return value

# 获取配置列表化
def get_list(key: str):
    value = get(key)
    if value:
        value = list(filter(None, value.split("&&")))
    return value

免费评分

参与人数 5吾爱币 +3 热心值 +5 收起 理由
xnink + 1 谢谢@Thanks!
guo15049434245 + 1 谢谢@Thanks!
ywqn + 1 + 1 谢谢@Thanks!用过,顶一个
二十瞬 + 1 + 1 谢谢分享 上一个效果图就更好了
lvmins + 1 + 1 我很赞同!

查看全部评分

本帖被以下淘专辑推荐:

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

yunfu 发表于 2022-9-20 17:22
感谢楼主分享!怎样使用
鸡多不压身 发表于 2022-9-20 17:40
Bingguner 发表于 2022-9-24 10:46
夜O无眠 发表于 2022-9-26 16:42
感谢分享!!!
li1733518 发表于 2022-9-28 00:36
感谢分享
薄了微凉 发表于 2022-9-28 17:59
感谢分享,尝试搭建已成功
hsx778899 发表于 2023-1-14 10:29
阿里云函数能挂吗?
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2025-1-11 21:42

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表