基于Python制作短信发送程序
作者:虚坏叔叔 发布时间:2022-06-19 16:47:25
标签:Python,短信,发送
一、Python短信发送界面最后的效果
二、准备:注册腾讯云账号并配置短信功能
(1)注册腾讯云账号
登录腾讯云网址
(2)获取AppID、AppKey
在短信功能页面下,从应用管理>应用列表,获取ID、Key。
(3)创建签名
在短信功能页面下,进入国内短信>签名管理,创建签名。
(4)创建正文模板
在短信功能页面下,进入国内短信>正文模板管理,创建模版。并获取模板ID备用。
三.初始化短信发送程序窗口
3.1初始化窗口菜单
菜单具备打开手机号码文件、保存记录、查看版本等功能。
menu=tkinter.Menu(root)
submenu1 = tkinter.Menu(menu, tearoff=0)
submenu1.add_command(label='打开', command=open_file)
submenu1.add_command(label='保存', command=save_file)
menu.add_cascade(label='文件',menu=submenu1)
submenu3 = tkinter.Menu(menu, tearoff=0)
submenu3.add_command(label='版本信息', command=Introduction)
menu.add_cascade(label='帮助',menu=submenu3)
root.config(menu=menu)
3.2初始化窗口控件
控件包括号码输入框、发送信息按钮,记录显示框。
global text1,text2
label1 = tkinter.Label(root, text="手机号码:", font=("微软雅黑", 18))
label1.place(x=30,y=32)
text1 = tkinter.Text(root, wrap = 'none', font=("微软雅黑", 18))
text1.place(x=30+120,y=30, width=520-120-100, height=40)
button=tkinter.Button(root, text='发送信息',width=10, height=20, bg='gray', fg='white', font=("微软雅黑", 12),command=send_Button)
button.place(x=480,y=30,width=70, height=40)
sx = tkinter.Scrollbar(root,orient = tkinter.HORIZONTAL)
sx.pack(side = tkinter.BOTTOM,fill = tkinter.X)
sy = tkinter.Scrollbar(root)
sy.pack(side = tkinter.RIGHT,fill = tkinter.Y)
text2 = tkinter.Text(root, yscrollcommand = sy.set, xscrollcommand = sx.set, wrap = 'none', font=("微软雅黑", 10))
text2.place(x=30,y=100, width=520, height=400)
text2.config(wrap=tkinter.WORD)
text2.see(tkinter.END);
sx.config(command = text2.xview)
sy.config(command = text2.yview)
3.3编写事件触发程序
3.3.1文件打开
def open_file():
global file_path,phone_numbers,flag
file_path = filedialog.askopenfilename()
if file_path is not "":
data=pandas.read_excel(file_path)
phone = data['号码'].tolist()
for i in range(len(phone)):
phone_numbers.append(str(phone[i]))
text2.insert(tkinter.END,"*********************************"+"\n", '\n')
text2.see(tkinter.END);
text2.insert(tkinter.END,"打开文件成功!"+"\n", '\n')
text2.see(tkinter.END);
text2.insert(tkinter.END,"文件路径为:"+file_path+"\n", '\n')
text2.see(tkinter.END);
text2.insert(tkinter.END,"文件内容如下:"+"\n", '\n')
text2.see(tkinter.END);
text2.insert(tkinter.END,data, '\n')
text2.see(tkinter.END);
text2.insert(tkinter.END,"\n", '\n')
text2.see(tkinter.END);
flag = 1
else:
text2.insert(tkinter.END,"*********************************"+"\n", '\n')
text2.see(tkinter.END);
text2.insert(tkinter.END,"您未打开文件!"+"\n", '\n')
text2.see(tkinter.END);
flag = 0
3.3.2文件保存
def save_file():
file=open("recorde.txt","a+")
content=str(text2.get("0.0", "end"))
file.write(content)
file.close()
text2.insert(tkinter.END,"*********************************"+"\n", '\n')
text2.see(tkinter.END);
text2.insert(tkinter.END,"保存记录到recorde.txt成功!"+"\n", '\n')
text2.see(tkinter.END);
tkinter.messagebox.showinfo('提示','保存记录到recorde.txt成功!')
text2.see(tkinter.END);
3.3.3帮助菜单
def Introduction():
text2.insert(tkinter.END,"*********************************"+"\n", '\n')
text2.see(tkinter.END);
text2.insert(tkinter.END,"版本信息:短信息通知程序 V1.0"+"\n", '\n')
text2.see(tkinter.END);
tkinter.messagebox.showinfo('版本信息' ,'短信息通知程序 V1.0')
text2.see(tkinter.END);
3.3.4发送按钮
def send_Button():
global flag,phone_numbers
appid = "你的appid"
appkey = "你的appkey"
template_id = "你的模板ID"
sms_sign = "你的公众号名称"
params = []
ssl._create_default_https_context = ssl._create_unverified_context
ssender = SmsSingleSender(appid, appkey)
txt1 = str(text1.get("0.0", "end")).replace('\n', '')
if flag==0:
if ',' in txt1:
phone_numbers=str(text1.get("0.0", "end")).replace('\n', '').split(',')
elif ',' in txt1:
phone_numbers=str(text1.get("0.0", "end")).replace('\n', '').split(',')
else:
phone_numbers=[]
phone_numbers.append(txt1)
else:
flag = 0
count=0
for l in phone_numbers:
count=count+len(str(l))
if count%11==0:
result = ""
for i in range(len(phone_numbers)):
try:
result = ssender.send_with_param(86, phone_numbers[i],template_id, params, sign=sms_sign, extend="", ext="")
except HTTPError as e:
result=e
except Exception as e:
result=e
text2.insert(tkinter.END,"*********************************"+"\n", '\n')
text2.see(tkinter.END);
text2.insert(tkinter.END,"信息发送至手机号:"+"\n"+str(phone_numbers[i])+"\n")
text2.see(tkinter.END);
text2.insert(tkinter.END,"信息发送返回结果:"+"\n")
text2.see(tkinter.END);
text2.insert(tkinter.END,str(result)+"\n", '\n')
text2.see(tkinter.END);
if result['errmsg']=='OK':
text2.insert(tkinter.END,"信息发送至【"+str(phone_numbers[i])+"】成功!"+"\n")
text2.see(tkinter.END);
else:
text2.insert(tkinter.END,"信息发送至【"+str(phone_numbers[i])+"】失败!"+"\n")
text2.see(tkinter.END);
else:
text2.insert(tkinter.END,"*********************************"+"\n", '\n')
text2.see(tkinter.END);
text2.insert(tkinter.END,"手机号码格式不正确"+"\n", '\n')
text2.see(tkinter.END);
四、完整源代码
import tkinter
import tkinter.messagebox
from tkinter import filedialog
import pandas
import ssl
from qcloudsms_py import SmsSingleSender
from qcloudsms_py.httpclient import HTTPError
def open_file():
global file_path,phone_numbers,flag
file_path = filedialog.askopenfilename()
if file_path is not "":
data=pandas.read_excel(file_path)
phone = data['号码'].tolist()
for i in range(len(phone)):
phone_numbers.append(str(phone[i]))
text2.insert(tkinter.END,"*********************************"+"\n", '\n')
text2.see(tkinter.END);
text2.insert(tkinter.END,"打开文件成功!"+"\n", '\n')
text2.see(tkinter.END);
text2.insert(tkinter.END,"文件路径为:"+file_path+"\n", '\n')
text2.see(tkinter.END);
text2.insert(tkinter.END,"文件内容如下:"+"\n", '\n')
text2.see(tkinter.END);
text2.insert(tkinter.END,data, '\n')
text2.see(tkinter.END);
text2.insert(tkinter.END,"\n", '\n')
text2.see(tkinter.END);
flag = 1
else:
text2.insert(tkinter.END,"*********************************"+"\n", '\n')
text2.see(tkinter.END);
text2.insert(tkinter.END,"您未打开文件!"+"\n", '\n')
text2.see(tkinter.END);
flag = 0
def save_file():
file=open("recorde.txt","a+")
content=str(text2.get("0.0", "end"))
file.write(content)
file.close()
text2.insert(tkinter.END,"*********************************"+"\n", '\n')
text2.see(tkinter.END);
text2.insert(tkinter.END,"保存记录到recorde.txt成功!"+"\n", '\n')
text2.see(tkinter.END);
tkinter.messagebox.showinfo('提示','保存记录到recorde.txt成功!')
text2.see(tkinter.END);
def Introduction():
text2.insert(tkinter.END,"*********************************"+"\n", '\n')
text2.see(tkinter.END);
text2.insert(tkinter.END,"版本信息:短信息通知程序 V1.0"+"\n", '\n')
text2.see(tkinter.END);
tkinter.messagebox.showinfo('版本信息' ,'短信息通知程序 V1.0')
text2.see(tkinter.END);
def send_Button():
global flag,phone_numbers
appid = "你的appid"
appkey = "你的appkey"
template_id = "你的模板ID"
sms_sign = "你的公众号名称"
params = []
ssl._create_default_https_context = ssl._create_unverified_context
ssender = SmsSingleSender(appid, appkey)
txt1 = str(text1.get("0.0", "end")).replace('\n', '')
if flag==0:
if ',' in txt1:
phone_numbers=str(text1.get("0.0", "end")).replace('\n', '').split(',')
elif ',' in txt1:
phone_numbers=str(text1.get("0.0", "end")).replace('\n', '').split(',')
else:
phone_numbers=[]
phone_numbers.append(txt1)
else:
flag = 0
count=0
for l in phone_numbers:
count=count+len(str(l))
if count%11==0:
result = ""
for i in range(len(phone_numbers)):
try:
result = ssender.send_with_param(86, phone_numbers[i],template_id, params, sign=sms_sign, extend="", ext="")
except HTTPError as e:
result=e
except Exception as e:
result=e
text2.insert(tkinter.END,"*********************************"+"\n", '\n')
text2.see(tkinter.END);
text2.insert(tkinter.END,"信息发送至手机号:"+"\n"+str(phone_numbers[i])+"\n")
text2.see(tkinter.END);
text2.insert(tkinter.END,"信息发送返回结果:"+"\n")
text2.see(tkinter.END);
text2.insert(tkinter.END,str(result)+"\n", '\n')
text2.see(tkinter.END);
if result['errmsg']=='OK':
text2.insert(tkinter.END,"信息发送至【"+str(phone_numbers[i])+"】成功!"+"\n")
text2.see(tkinter.END);
else:
text2.insert(tkinter.END,"信息发送至【"+str(phone_numbers[i])+"】失败!"+"\n")
text2.see(tkinter.END);
else:
text2.insert(tkinter.END,"*********************************"+"\n", '\n')
text2.see(tkinter.END);
text2.insert(tkinter.END,"手机号码格式不正确"+"\n", '\n')
text2.see(tkinter.END);
def init_frame(root):
menu=tkinter.Menu(root)
submenu1 = tkinter.Menu(menu, tearoff=0)
submenu1.add_command(label='打开', command=open_file)
submenu1.add_command(label='保存', command=save_file)
menu.add_cascade(label='文件',menu=submenu1)
submenu3 = tkinter.Menu(menu, tearoff=0)
submenu3.add_command(label='版本信息', command=Introduction)
menu.add_cascade(label='帮助',menu=submenu3)
root.config(menu=menu)
global text1,text2
label1 = tkinter.Label(root, text="手机号码:", font=("微软雅黑", 18))
label1.place(x=30,y=32)
text1 = tkinter.Text(root, wrap = 'none', font=("微软雅黑", 18))
text1.place(x=30+120,y=30, width=520-120-100, height=40)
button=tkinter.Button(root, text='发送信息',width=10, height=20, bg='gray', fg='white', font=("微软雅黑", 12),command=send_Button)
button.place(x=480,y=30,width=70, height=40)
sx = tkinter.Scrollbar(root,orient = tkinter.HORIZONTAL)
sx.pack(side = tkinter.BOTTOM,fill = tkinter.X)
sy = tkinter.Scrollbar(root)
sy.pack(side = tkinter.RIGHT,fill = tkinter.Y)
text2 = tkinter.Text(root, yscrollcommand = sy.set, xscrollcommand = sx.set, wrap = 'none', font=("微软雅黑", 10))
text2.place(x=30,y=100, width=520, height=400)
text2.config(wrap=tkinter.WORD)
text2.see(tkinter.END);
sx.config(command = text2.xview)
sy.config(command = text2.yview)
root.update()
if __name__=="__main__":
global flag
flag = 0
global phone_numbers
phone_numbers = []
root = tkinter.Tk()
root.title("短信息发送程序")
root.geometry('600x520')
init_frame(root)
root.mainloop()
来源:https://blog.csdn.net/biggbang/article/details/127231278


猜你喜欢
- 4 月 27 日,GitHub 趋势榜第 3 位是一个用 Python 编码实现的算法库,Star 数早已达到 26000+链接:https
- 前提条件,两台服务器都安装了mysql相同的版本,数据库名也一样,最好数据都是尽量的差不多。mysql服务器端 192.168.0.1: 新
- 前后端分离前后端分离的好处最大的好处就是前端JS可以做很大部分的数据处理工作,对服务器的压力减小到最小。后台错误不会直接反映到前台,错误接秒
- 如题在SQL中 SELECT ... FROM ... ORDER BY abc ASC; 如果abc是字符串,那么结果会按照a-z 中文按
- Go 程序运行时,有些场景下会导致进程进入某个“高点”,然后就再也下不来了。比如,多年前曹大写过的一
- 1.Vue.js介绍 当前前端三大主流框架:Angula
- 来看看javascript怎么实现自动点击超级链接吧,主要使用了js中的onclick事件。这里推荐大家看看这篇文章js鼠标事件大全。看了这
- 总说由于pytorch 0.4版本更新实在太大了, 以前版本的代码必须有一定程度的更新. 主要的更新在于 Variable和Tensor的合
- 一个asp读取数据库中数据到数组的类,仅供参考!DbPath = "test.mdb"’数据库位置&
- 一个简单的PHP循环一维数组的实例,先是把字符串按照一定的规则进行转换成为数组,然后再进行遍历输出,实际是一个很简单的方法,因为最近做的一个
- 一、new做了哪些事先看看new的使用场景:// 1、创建一个构造函数function Vehicle(name, price) { &nb
- 通过无能的baidu逛了一圈,发现有两三段能用的代码,不过参考之下,发现还有不足的:不能拷贝有合并格式的sheet、没有拷贝cell的相关格
- 一 概念Django的ORM中存在查询集的概念。查询集,也称查询结果集、QuerySet,表示从数据库中获取的对象集合。当调用如下过滤器方法
- 微信小程序获取位置信息的方式有两种,一种是调用微信官方的接口来获取,如getLocation,这种方式只能获取经纬度微信官方文档https:
- #!/usr/bin/env python# -*- coding: utf8 -*-import MySQLdbimport timeim
- 回收站(Recycle Bin)从原理上来说就是一个数据字典表,放置用户删除(drop)掉的数据库对象信息。用户进行删除操作的对象并没有被数
- 本文实例为大家分享了jQuery轮播效果展示的具体代码,供大家参考,具体内容如下jQ代码: 在写jQuery代码之前一定要先导库,此处我用的
- 1、一般CentOS默认安装了mariadb,所以先查看是否安装mariadb,如果安装就需要先卸载mariadbrpm -qa|grep
- 在现实的图像操作软件中,经常碰到的不是给出放大多少倍,而是由用户在软件的界面上选择多大的区域,或者选择几个点,那么这样情况下,怎么样来计算出
- mysql 模糊查询 concat()concat() 函数,是用来连接字符串。精确查询: select * from user where