基于python tkinter的点名小程序功能的实例代码


Posted in Python onAugust 22, 2020

代码如下所示:

import datetime
import json
import os
import random
import tkinter as tk
import openpyxl

# 花名册文件名
excel_file_path = "花名册.xlsx"#需在当前目录创建对应花名册.xlsx
# 工作表名
excel_sheet = "Sheet1"
# 记录存储文件名
file_path = "name_record.json"

#封装业务逻辑
class Call_Name:
 # 私有化变量
 _namelist = None
 # 读取花名册
 def __init__(self):
  wb = openpyxl.load_workbook(excel_file_path)
  get_sheet = wb[excel_sheet]
  list_data = []
  first_row = True
  try:
   for row in get_sheet:
    # 忽略首行
    if first_row:
     first_row = False
     continue
    # 读取第一个单元格数据
    for lab in row:
     list_data.append(lab.value)
     break
  except:
   list_data = ['空名单?']
  self._namelist = list_data

 # 初始化记录
 def _re_reset(self):
  # 记录使用日期
  dls = []
  dy = str(datetime.datetime.today().date())
  dls.append(dy)
  # 记录点名
  record = {}
  for i in self._namelist:
   record[i] = 0
  name_record = {"date": dls, "last_use": dy, "record": record}
  return name_record

 # 创建记录
 def mk_record(self):
  jf_dict = self._re_reset()
  with open(file=file_path, mode='w', encoding='utf-8') as jf:
   json.dump(jf_dict, jf, indent=2, sort_keys=True, ensure_ascii=False)

 # 读取记录
 def read_record(self):
  with open(file=file_path, mode='r', encoding='utf-8') as jf:
   jf_data = json.load(jf)
  return jf_data

 # 产生随机姓名
 def call_name(self):
  ll = len(self._namelist)
  num = random.randint(1, ll)
  call_name = self._namelist[num - 1]
  return call_name

 # 修改记录-----warning!!!
 def re_mod(self, name=None, re_date=None):
  jf_data = self.read_record()
  record = jf_data["record"]
  use_date = list(jf_data["date"])
  if name:
   v = record[name] + 1
   jf_data["record"][name] = v
  if re_date:
   use_date.append(re_date)
   jf_data["date"] = use_date
   jf_data["last_use"] = re_date
  with open(file=file_path, mode='w', encoding='utf-8') as jf:
   json.dump(jf_data, jf, indent=2, sort_keys=True, ensure_ascii=False)

 # 获取记录次数
 def re_times(self):
  times_list = []
  record = self.read_record()["record"]
  for k, v in record.items():
   times_list.append(v)
  return times_list # 返回记录次数

 # 获取被点到成员记录次数
 def call_times(self, name):
  record = self.read_record()["record"]
  return record[name]

#封装事件
class ForGUI:
 # 初始化
 re_date = None

 def __init__(self):
  try:
   cname = Call_Name()
  except:
   msg["text"] = "未找到:%s" % excel_file_path
   msg.update()
  else:
   try:
    record = cname.read_record() # 读取记录
   except:
    cname.mk_record() # 读取异常则重新创建记录
    record = cname.read_record()
   self.re_date = record["date"] # 获取使用日期记录
   # 每5天初始化一次记录
   if len(self.re_date) > 5:
    cname.mk_record() # 重新创建记录

 # 开始点名,输出有效姓名:姓名对应记录不为最大次数
 def start(self):
  cname = Call_Name()
  times = cname.re_times() # 获取记录次数
  max_times = max(times) # 获取记录最大次数
  min_times = min(times) # 获取记录最小次数
  td = str(datetime.datetime.today().date()) # 获取当前日期
  if not td in self.re_date:
   cname.re_mod(re_date=td)
  while True:
   name = cname.call_name() # 产生随机姓名
   times = cname.call_times(name) # 获取被点到成员记录次数
   if max_times != min_times:
    if times != max_times:
     cname.re_mod(name=name) # 修改记录
     msg["text"] = name
     msg.update()
     break
    else:
     continue
   else:
    cname.re_mod(name=name) # 修改记录
    msg["text"] = name
    msg.update()
    break

 # 查看花名册
 def open_name_excel(self):
  try:
   os.system("start %s&exit" % excel_file_path)
  except:
   msg["text"] = '\n未找到花名册?(???)?\n'
   msg["font"] = ('', 18)
   msg.update()

 # 查看点名记录
 def open_record(self):
  try:
   os.system("start %s&exit" % file_path)
  except:
   msg["text"] = '\n未找到点名记录?(???)?\n'
   msg["font"] = ('', 18)
   msg.update()

 # 获取花名册名单
 def get_name_list(self):
  try:
   wb = openpyxl.load_workbook(excel_file_path)
   get_sheet = wb[excel_sheet]
  except:
   msg["text"] = "未找到:%s" % excel_file_path
   msg.update()
  else:
   list_data = []
   first_row = True
   for row in get_sheet:
    # 忽略首行
    if first_row:
     first_row = False
     continue
    # 读取第一个单元格数据
    for lab in row:
     list_data.append(lab.value)
     break
   return list_data

# 创建窗口
root = tk.Tk(className="点名工具")
# 设置窗口大小
setWidth = 300
setHeight = 180
# 获取屏幕分辨率
screenWidth = root.winfo_screenwidth()
screenHeight = root.winfo_screenheight()

x = int((screenWidth - setWidth) / 2)
y = int((screenHeight - setHeight) / 2)
# 设置窗口初始位置屏幕居中
root.geometry("%sx%s+%s+%s" % (setWidth, setHeight, x, y))
# 设置窗口宽高固定
root.resizable(0, 0)
# 创建菜单栏
m1 = tk.Menu(root, tearoff=False)
# 创建子菜单,不显示分窗
MenuBar = tk.Menu(m1, tearoff=False)
MenuBar.add_command(label='查看名单', command=ForGUI().open_name_excel)
MenuBar.add_command(label='查看记录', command=ForGUI().open_record)
MenuBar.add_command(label='清空记录', command=Call_Name().mk_record)

# 将子菜单加入菜单栏中
m1.add_cascade(label='选项', menu=MenuBar)
m1.add_command(label='Exit', command=root.quit)
# 将菜单栏添加到窗口
root.config(menu=m1)
# 创建文本显示
f1 = tk.Frame(root, bd=1, height=150, width=200)
pass
f1.pack(pady=10)
msg = tk.Label(f1, text="\n别紧张(●ˇ∀ˇ●)\n", fg="green") # 创建文本控件
msg.pack(pady=10)
msg["font"] = ('', 18)
f2 = tk.Frame(root)
f2.pack(pady=10)

# 循环随机显示花名册名单
name_list = ForGUI().get_name_list()
def info():
 t = random.randint(1, len(name_list))
 msg["font"] = ('', 44)
 msg["text"] = (name_list[t - 1])

def bt_listen():
 while bt["state"] == 'normal':
  bt['command'] = bt_start
  bt['text'] = "就决定是你了"
  root.after(500, info)
  bt.update()
  if bt['text'] == "开始":
   break
def bt_start():
 bt['command'] = bt_listen
 bt['text'] = "开始"
 fg = ForGUI()
 root.after(500, fg.start)
 bt.update()

# 创建开始按钮
bt = tk.Button(f2, text='开始点名喽', stat="normal", command=bt_listen, bd=4, width=20, font=18)
bt.pack()
root.mainloop()

总结

到此这篇关于基于python tkinter的点名小程序功能的实例代码的文章就介绍到这了,更多相关python tkinter点名小程序内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Python实现子类调用父类的方法
Nov 10 Python
python3 unicode列表转换为中文的实例
Oct 26 Python
django做form表单的数据验证过程详解
Jul 26 Python
python 标准差计算的实现(std)
Jul 29 Python
django 环境变量配置过程详解
Aug 06 Python
python机器学习包mlxtend的安装和配置详解
Aug 21 Python
python使用 request 发送表单数据操作示例
Sep 25 Python
tensorflow ckpt模型和pb模型获取节点名称,及ckpt转pb模型实例
Jan 21 Python
Python基础之字典常见操作经典实例详解
Feb 26 Python
python图片剪裁代码(图片按四个点坐标剪裁)
Mar 10 Python
pygame实现飞机大战
Mar 11 Python
pip安装提示Twisted错误问题(Python3.6.4安装Twisted错误)
May 09 Python
python+selenium 简易地疫情信息自动打卡签到功能的实现代码
Aug 22 #Python
python进度条显示之tqmd模块
Aug 22 #Python
python 常见的排序算法实现汇总
Aug 21 #Python
Python制作数据预测集成工具(值得收藏)
Aug 21 #Python
简述 Python 的类和对象
Aug 21 #Python
DRF框架API版本管理实现方法解析
Aug 21 #Python
Django rest framework分页接口实现原理解析
Aug 21 #Python
You might like
Windows2003 下 MySQL 数据库每天自动备份
2006/12/21 PHP
Javascript Math ceil()、floor()、round()三个函数的区别
2010/03/09 Javascript
jQuery 顺便学习下CSS选择器 奇偶匹配nth-child(even)
2010/05/24 Javascript
IE6,IE7下js动态加载图片不显示错误
2010/07/17 Javascript
编写可维护面向对象的JavaScript代码[翻译]
2011/02/12 Javascript
JavaScript快速检测浏览器对CSS3特性的支持情况
2012/09/26 Javascript
js螺旋动画效果的具体实例
2013/11/15 Javascript
一个JavaScript处理textarea中的字符成每一行实例
2014/09/22 Javascript
AngularJS中的过滤器使用详解
2015/06/16 Javascript
详解Javascript ES6中的箭头函数(Arrow Functions)
2016/08/24 Javascript
js求数组中全部数字可拼接出的最大整数示例代码
2017/08/25 Javascript
信息滚动效果的实例讲解
2017/09/18 Javascript
vue实现文件上传功能
2018/08/13 Javascript
js键盘事件实现人物的行走
2020/01/17 Javascript
javascript实现贪吃蛇小练习
2020/07/05 Javascript
vue3中轻松实现switch功能组件的全过程
2021/01/07 Vue.js
[53:52]EG vs VGJ.T 2018国际邀请赛小组赛BO2 第一场 8.16
2018/08/17 DOTA
Python构造函数及解构函数介绍
2015/02/26 Python
python Django模板的使用方法
2016/01/14 Python
django1.11.1 models 数据库同步方法
2018/05/30 Python
Python API 自动化实战详解(纯代码)
2019/06/11 Python
Python用Try语句捕获异常的实例方法
2019/06/26 Python
Python获取好友地区分布及好友性别分布情况代码详解
2019/07/10 Python
新加坡航空官方网站:Singapore Airlines
2016/10/13 全球购物
澳大利亚最大的女装零售商:Millers
2017/09/10 全球购物
俄罗斯最大的在线手表商店:Bestwatch.ru
2020/01/11 全球购物
用你熟悉的语言写一个连接ORACLE数据库的程序,能够完成修改和查询工作
2012/06/11 面试题
介绍一下游标
2012/01/10 面试题
销售总经理岗位职责
2014/03/15 职场文书
高中生个性发展自我评价
2015/03/09 职场文书
大学副班长竞选稿
2015/11/21 职场文书
导游词书写之黄山
2019/08/06 职场文书
深入理解redis中multi与pipeline
2021/06/02 Redis
Java详细解析==和equals的区别
2022/04/07 Java/Android
python中pymysql包操作数据库方法
2022/04/19 Python
利用Java连接Hadoop进行编程
2022/06/28 Java/Android