当前位置: 首页 > article >正文

Python自动化:调用企业微信API高效推送邮件通知

1. 为什么需要企业微信邮件自动化每天手动发送运营报告的日子我受够了。作为团队的技术负责人曾经每周都要花2小时整理数据、写邮件、检查收件人列表。直到发现企业微信API能实现全自动化现在整个过程只需30秒准确率还更高。企业微信的邮件API功能比你想象的强大。它不仅能发送普通文本邮件还支持HTML格式、附件上传、群发管理等功能。我们团队用它实现了每日凌晨自动发送前一日销售数据系统异常实时邮件报警周报自动汇总分发客户生日祝福自动触发最让我惊喜的是API调用成功率高达99.9%比人工操作更可靠。上周服务器宕机时报警邮件比监控系统还早3分钟到达运维人员邮箱。2. 准备工作获取API通行证2.1 创建企业微信应用登录企业微信管理后台在应用管理点击创建应用。建议命名规范如邮件自动化_部门_用途我们用的是MailBot_Tech_DailyReport。创建完成后会看到三个关键参数AgentId应用的身份证号如1000002CorpId企业的统一标识Secret相当于应用密码务必保管好我犯过的错第一次把Secret保存在代码里直接提交到了GitHub结果被安全团队警告。现在都用环境变量存储# 在Linux/macOS的~/.bashrc添加 export WX_CORP_IDyour_corp_id export WX_APP_SECRETyour_app_secret2.2 配置邮件服务器进入邮件-邮件服务器配置需要准备SMTP服务器地址如smtp.exmail.qq.com端口号通常465或587管理员邮箱需开通SMTP服务授权码不是邮箱密码测试时遇到过坑腾讯企业邮箱要求用授权码而非密码这个设置藏得很深在邮箱设置-账户-安全设置里。3. Python实战从零编写发送脚本3.1 获取AccessTokenAccessToken是API调用的门票有效期2小时。建议用这个缓存方案import requests import time from os import environ TOKEN_CACHE { token: None, expires_at: 0 } def get_access_token(): if TOKEN_CACHE[token] and time.time() TOKEN_CACHE[expires_at]: return TOKEN_CACHE[token] url fhttps://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid{environ[WX_CORP_ID]}corpsecret{environ[WX_APP_SECRET]} resp requests.get(url).json() TOKEN_CACHE.update({ token: resp[access_token], expires_at: time.time() resp[expires_in] - 300 # 提前5分钟刷新 }) return TOKEN_CACHE[token]3.2 发送带附件的邮件这是我们正在用的增强版发送函数def send_email_with_attachment(subject, content, to_users, filesNone): token get_access_token() url https://qyapi.weixin.qq.com/cgi-bin/message/send payload { touser: to_users, msgtype: file, agentid: environ.get(WX_AGENT_ID), file: { media_id: upload_file(token, files[0]) if files else }, text: { content: f{subject}\n\n{content} }, safe: 0 } response requests.post( url, params{access_token: token}, jsonpayload ) return response.json() def upload_file(token, filepath): url fhttps://qyapi.weixin.qq.com/cgi-bin/media/upload?access_token{token}typefile with open(filepath, rb) as f: return requests.post(url, files{media: f}).json()[media_id]4. 高级技巧与避坑指南4.1 收件人智能处理我们开发了动态收件人系统def get_recipients_by_department(dept_id): url fhttps://qyapi.weixin.qq.com/cgi-bin/user/list?access_token{get_access_token()}department_id{dept_id} users requests.get(url).json().get(userlist, []) return |.join(user[userid] for user in users) # 发送给技术部全体 tech_users get_recipients_by_department(2) send_email_with_attachment(技术周报, weekly_report, tech_users)4.2 错误处理与重试机制企业微信API偶尔会返回40001token过期错误这是我们的解决方案def safe_send_email(max_retry3, **kwargs): for i in range(max_retry): try: result send_email_with_attachment(**kwargs) if result.get(errcode) 0: return True if result.get(errcode) 40001: TOKEN_CACHE[token] None # 强制刷新token except Exception as e: print(fAttempt {i1} failed: {str(e)}) time.sleep(2 ** i) # 指数退避 return False5. 自动化实战定时发送运营报表用APScheduler实现定时任务from apscheduler.schedulers.blocking import BlockingScheduler def generate_daily_report(): # 这里连接数据库生成报告 return 昨日UV: 15243\nPV: 87421\n转化率: 3.2% scheduler BlockingScheduler() scheduler.scheduled_job(cron, hour8, minute30) def morning_report(): report generate_daily_report() send_email_with_attachment( subject每日运营简报, contentreport, to_usersget_recipients_by_department(3), files[/reports/daily_stats.pdf] ) scheduler.start()我在服务器部署时发现直接用nohup运行会丢失日志后来改用supervisor管理进程[program:wx_mail_bot] commandpython /opt/scripts/mail_bot.py autostarttrue autorestarttrue stderr_logfile/var/log/wx_mail_err.log stdout_logfile/var/log/wx_mail_out.log

相关文章:

Python自动化:调用企业微信API高效推送邮件通知

1. 为什么需要企业微信邮件自动化 每天手动发送运营报告的日子我受够了。作为团队的技术负责人,曾经每周都要花2小时整理数据、写邮件、检查收件人列表。直到发现企业微信API能实现全自动化,现在整个过程只需30秒,准确率还更高。 企业微信的邮…...

G-Helper华硕笔记本优化指南:三步告别臃肿控制中心,性能提升30%

G-Helper华硕笔记本优化指南:三步告别臃肿控制中心,性能提升30% 【免费下载链接】g-helper Lightweight, open-source control tool for ASUS laptops and ROG Ally. Manage performance modes, fans, GPU, battery, and RGB lighting across Zephyrus, …...

【C++笔记】STL详解: stack 和 queue 的使用

前言:在 C 的标准模板库 (STL) 中,stack(栈)和 queue(队列)是非常重要且常用的数据结构。它们都属于“容器适配器”,这意味着它们不是从零开始构建的,而是封装了其他底层容器&#x…...

别再乱改组策略了!深入理解CredSSP更新与远程桌面安全的正确配置姿势

深入解析CredSSP安全机制与远程桌面连接的最佳实践 1. CredSSP协议与加密Oracle漏洞的本质 CredSSP(Credential Security Support Provider)协议是微软开发的一种身份验证协议,主要用于远程桌面连接等场景下的凭据安全传输。2018年曝光的CVE-…...

如何快速下载网页视频:猫抓(cat-catch)浏览器扩展完全指南

如何快速下载网页视频:猫抓(cat-catch)浏览器扩展完全指南 【免费下载链接】cat-catch 猫抓 浏览器资源嗅探扩展 / cat-catch Browser Resource Sniffing Extension 项目地址: https://gitcode.com/GitHub_Trending/ca/cat-catch 猫抓(cat-catch)是一款功能强…...

[嵌入式系统]的[WiFi网络配置]:从[连接不稳定]到[可靠通信]的实践指南

[嵌入式系统]的[WiFi网络配置]:从[连接不稳定]到[可靠通信]的实践指南 【免费下载链接】arduino-esp32 Arduino core for the ESP32 项目地址: https://gitcode.com/GitHub_Trending/ar/arduino-esp32 1. 问题发现:WiFi连接的隐形障碍 当我们在开…...

C#开发者必看:INIFileParser库解决INI配置文件乱码问题的实战指南

C#开发者必看:INIFileParser库解决INI配置文件乱码问题的实战指南 在Windows应用开发中,INI文件作为一种轻量级配置存储格式,至今仍被广泛使用。但许多C#开发者发现,当配置文件路径包含中文、空格或特殊字符时,传统的W…...

计算机毕设源码到底包含什么?一文搞懂标准交付物结构

一、为什么你的毕设源码总被导师打回? 每年毕业季,无数计算机专业学生都会遇到这样的场景:“导师看了一眼你的毕设源码,眉头一皱:‘这交付的什么?数据库脚本呢?接口文档呢?怎么连部署…...

Qwen3.5-9B Visio图表智能生成:根据文本描述自动创建流程图与架构图

Qwen3.5-9B Visio图表智能生成:根据文本描述自动创建流程图与架构图 1. 引言:告别手动绘图的烦恼 你有没有遇到过这样的情况?开会讨论完一个业务流程,需要把它画成流程图;或者设计了一个系统架构,得在Vis…...

避坑指南:RAG Pipeline中多阶段处理的5个性能陷阱与优化方案(附Qwen-Turbo限流配置)

RAG Pipeline性能优化实战:五大关键陷阱与云服务适配方案 当你的RAG系统从Demo走向生产环境时,PDF解析突然内存溢出,向量数据库写入耗时呈指数增长,API调用频繁触发限流——这些性能陷阱往往在真实业务压力下才会暴露。本文将解剖…...

【Python并发成本控制终极指南】:GIL移除后3大无锁模型选型公式与ROI量化对比表

第一章:Python无锁GIL环境下的并发成本控制全景图Python 的全局解释器锁(GIL)长期被视为多线程 CPU 密集型任务的性能瓶颈。然而,随着 CPython 3.13 引入实验性无锁 GIL(--without-pymalloc 配合 --with-experimental-…...

单片机自动脱模剂喷雾控制系统

/***实现功能:检测报警信号,脱模剂开模数计数信号***/ /***参数:1:脱模剂开模数 2:喷雾时间 3:延时时间 ***/ /***串口接收触摸屏参数设置字符串,接收并保存******/ /***端子输入口读开模数,比较设定值后输出到电磁阀**/ /***端子输入口读报警信号,到设定值关闭电机及加热**/#i…...

避坑指南:用Docker部署Oracle 11g时你一定会遇到的5个权限问题(附终极解决方案)

避坑指南:用Docker部署Oracle 11g时你一定会遇到的5个权限问题(附终极解决方案) 在容器化技术席卷全球的今天,Docker已成为部署数据库的首选工具之一。然而,当我们将Oracle 11g这样的传统数据库巨人塞进轻量级容器时&a…...

Java SpringBoot+Vue3+MyBatis 信息化在线教学平台系统源码|前后端分离+MySQL数据库

摘要 随着信息技术的快速发展,教育行业正逐步向数字化、智能化转型。传统的线下教学模式受限于时间和空间,难以满足现代教育的高效性和灵活性需求。在线教学平台通过整合互联网技术与教育资源,为师生提供了便捷的交互渠道,有效提升…...

信号处理避坑指南:一维小波去噪中那些容易忽略的细节

信号处理避坑指南:一维小波去噪中那些容易忽略的细节 在信号处理领域,小波去噪因其优异的时频局部化特性,成为处理非平稳信号的首选方法。然而,许多工程师在应用PyWavelets等工具库时,往往陷入"调参陷阱"——…...

AI的恶意使用

AI 生成的内容与犯罪活动:人工智能系统正被滥用于生成诈骗、欺诈、敲诈勒索及未经同意的私密影像。尽管此类伤害的发生已有充分记录,但关于其发生率和严重程度的系统性数据仍然有限。 影响和操纵:在实验环境中,AI 生成的内容在改变…...

解锁3DS个性化定制:Anemone3DS主题管理器完全指南

解锁3DS个性化定制:Anemone3DS主题管理器完全指南 【免费下载链接】Anemone3DS A theme and boot splash manager for the Nintendo 3DS console 项目地址: https://gitcode.com/gh_mirrors/an/Anemone3DS 3DS主题定制是提升掌机使用体验的关键方式&#xff…...

Nanbeige 4.1-3B Streamlit WebUI效果展示:气泡时间戳与消息状态可视化

Nanbeige 4.1-3B Streamlit WebUI效果展示:气泡时间戳与消息状态可视化 1. 引言:当大模型遇见沉浸式聊天界面 想象一下,你正在本地部署一个强大的开源大语言模型,比如南北阁的4.1-3B版本。你通过命令行与它对话,看着…...

从相位差到厘米级精度:深入解析蓝牙6.0 CS中PBR公式的推导与验证

1. 蓝牙6.0 CS技术中的相位测距原理 蓝牙6.0引入的信道探测(CS)功能将定位精度提升到了厘米级,这主要得益于其采用的相位测距法(PBR)。想象一下,这就像用无线电波玩"激光测距",只不过我们用的是相位差而不是光脉冲。在实际操作中&a…...

5步打造Xbox 360游戏PC运行环境:Xenia Canary模拟器全攻略

5步打造Xbox 360游戏PC运行环境:Xenia Canary模拟器全攻略 【免费下载链接】xenia-canary Xbox 360 Emulator Research Project 项目地址: https://gitcode.com/gh_mirrors/xe/xenia-canary Xenia Canary作为领先的Xbox 360开源模拟器,通过精准的…...

手把手教你用Stable Diffusion v1.5:从安装到生成第一张AI图片

手把手教你用Stable Diffusion v1.5:从安装到生成第一张AI图片 1. 引言 你是否曾经想过,只需输入一段文字描述,就能让AI自动生成一张精美的图片?Stable Diffusion v1.5作为AI图像生成领域的经典模型,让这个梦想变成了…...

如何用RAKE-NLTK实现高效关键词提取:企业级文本分析解决方案

如何用RAKE-NLTK实现高效关键词提取:企业级文本分析解决方案 【免费下载链接】rake-nltk Python implementation of the Rapid Automatic Keyword Extraction algorithm using NLTK. 项目地址: https://gitcode.com/gh_mirrors/ra/rake-nltk 在信息爆炸的数字…...

Blender UV Squares终极指南:3分钟掌握UV网格重塑神器

Blender UV Squares终极指南:3分钟掌握UV网格重塑神器 【免费下载链接】UvSquares Blender addon for reshaping UV quad selection into a grid. 项目地址: https://gitcode.com/gh_mirrors/uv/UvSquares 在3D建模和纹理贴图的世界里,UV Squares…...

2026应届生面试避坑指南:避开这些致命细节,求职成功率翻倍

文章目录前言一、简历不是自传,而是广告文案第一个大坑:把简历做成PPT艺术展。第二个大坑:把简历写成流水账。第三个大坑:一份简历海投百家。二、八股文背得溜,场景题一到就露馅丢分细节一:只会背概念&…...

【新能源功率预测】别再只盯准确率了,2026真正决定收益的,是“预测+交易+储能”一体化

关键词: 新能源功率预测、电力现货交易、储能套利、AI大模型、容量电价 2026年的春天,对于新能源电站的投资人和运营者来说,可谓是“冰火两重天”。 “火”的是政策红利终于实质性落地。【发改价格】114号文将独立储能纳入容量电价体系&…...

终极指南:如何用dlssg-to-fsr3让老款RTX显卡享受帧生成技术

终极指南:如何用dlssg-to-fsr3让老款RTX显卡享受帧生成技术 【免费下载链接】dlssg-to-fsr3 Adds AMD FSR 3 Frame Generation to games by replacing Nvidia DLSS Frame Generation (nvngx_dlssg). 项目地址: https://gitcode.com/gh_mirrors/dl/dlssg-to-fsr3 …...

如何永久保存你的QQ空间记忆:GetQzonehistory完整备份指南

如何永久保存你的QQ空间记忆:GetQzonehistory完整备份指南 【免费下载链接】GetQzonehistory 获取QQ空间发布的历史说说 项目地址: https://gitcode.com/GitHub_Trending/ge/GetQzonehistory 你是否曾经担心过,那些记录着青春岁月的QQ空间说说会随…...

FramePack完整指南:5个关键技巧解决AI视频生成难题

FramePack完整指南:5个关键技巧解决AI视频生成难题 【免费下载链接】FramePack Lets make video diffusion practical! 项目地址: https://gitcode.com/gh_mirrors/fr/FramePack 你是否曾为AI视频生成中的内存溢出、生成速度缓慢和画面漂移问题而烦恼&#x…...

破解3DS游戏格式兼容难题:3dsconv工具的技术实现与应用指南

破解3DS游戏格式兼容难题:3dsconv工具的技术实现与应用指南 【免费下载链接】3dsconv Python script to convert Nintendo 3DS CCI (".cci", ".3ds") files to the CIA format 项目地址: https://gitcode.com/gh_mirrors/3d/3dsconv 问题…...

如何用iTorrent在iPhone上轻松管理种子下载?iOS种子客户端全攻略

如何用iTorrent在iPhone上轻松管理种子下载?iOS种子客户端全攻略 【免费下载链接】iTorrent Torrent client for iOS 16 项目地址: https://gitcode.com/gh_mirrors/it/iTorrent iTorrent是一款专为iOS 16设备设计的开源种子客户端,让iPhone和iPa…...