随机点名可视化界面,记录迟到人员,转exe文件

一.介绍

对于人员采取随机点名

二.代码

import datetime
import random
from tkinter import *
from tkinter.filedialog import * name_lis = []
print(name_lis)
root_1 = Tk()
e = StringVar()
x = StringVar()
root_1.title('随机点名') count = Label(root_1, text='输入点名的人数按回车确定')
count.grid(row=0, column=0) enter_1 = Entry(root_1, state='normal', textvariable=e)
enter_1.grid(row=0, column=1) enter_1.delete(0, END) # 初始显示
Window_1 = Listbox(root_1)
Window_1.insert(0, '请载入人员名单')
Window_1.grid(row=1, column=0, sticky=N + S) Window_2 = Listbox(root_1)
for name in ['人员名单格式', '请载入人员名单', '一个人员为一行', '文本为TXT格式']:
Window_2.insert(0, name)
Window_2.grid(row=1, column=1, sticky=N + S)
print(name_lis) def enter_chiose(a, enter=enter_1):
text = enter.get() # type:str
if text.isdigit():
if int(text) <= len(name_lis):
count_lis = ['点名人数:', f'{text}人']
Window_1 = Listbox(root_1)
Window_1.insert(0, count_lis)
Window_1.grid(row=1, column=0, sticky=N + S) print(text)
print(type(text))
num = int(text)
a = random.sample(name_lis, num)
names_lis = ['点名名单']
print(a)
if a:
names_lis.extend(a)
Window_2 = Listbox(root_1)
Window_2.grid(row=1, column=1, sticky=N + S)
for data in names_lis:
Window_2.insert(1, data)
else:
lis_1 = ['选择人数超过范围']
lis_2 = ['选择人数超过范围']
Window_1 = Listbox(root_1)
Window_1.insert(0, lis_1)
Window_1.grid(row=1, column=0, sticky=N + S)
Window_2 = Listbox(root_1)
Window_2.insert(0, lis_2)
Window_2.grid(row=1, column=1, sticky=N + S) else:
lis_1 = ['请输入数字']
lis_2 = ['请输入数字']
Window_1 = Listbox(root_1)
Window_1.insert(0, lis_1)
Window_1.grid(row=1, column=0, sticky=N + S)
Window_2 = Listbox(root_1)
Window_2.insert(0, lis_2)
Window_2.grid(row=1, column=1, sticky=N + S) enter_1.delete(0, 'end') count_2 = Label(root_1, text='未点到人员记事本')
count_2.grid(row=0, column=2) enter_2 = Entry(root_1, state='normal', textvariable=x)
enter_2.grid(row=1, column=2, sticky=N + S + E + W)
enter_2.delete(0, END) def b_save(enter=enter_2):
text = enter.get()
time = datetime.datetime.now()
time = str(time).split('.')[0]
enter.delete(0, 'end')
data = Label(enter, text=f'上次保存内容\n{time}\n{text}')
with open('迟到人员.txt', 'a', encoding='utf8') as fa:
fa.write(f'{time}\n{text}\n')
data.grid(row=0, column=0, sticky=N + S + E + W) save_b = Button(root_1, text='保存', command=b_save)
save_b.grid(row=2, column=2) enter_1.bind('<Return>', enter_chiose) def b_load():
fd = LoadFileDialog(root_1) # 创建打开文件对话框
filename = fd.go() # 显示打开文件对话框,并获取选择的文件名称
if filename:
try:
with open(filename, 'r', encoding='utf8') as fr:
name_lis.clear()
for name in fr:
name = name.strip()
name_lis.append(name)
except:
with open(filename, 'r', encoding='gbk') as fr:
name_lis.clear()
for name in fr:
name = name.strip()
name_lis.append(name) Window_1 = Listbox(root_1)
Window_1.insert(0, '人员名单')
Window_1.grid(row=1, column=0, sticky=N + S) Window_2 = Listbox(root_1)
for name in name_lis:
Window_2.insert(0, name)
Window_2.grid(row=1, column=1, sticky=N + S)
print(name_lis) load_b = Button(root_1, text='载入人员名单', command=b_load)
load_b.grid(row=2, column=0) root_1.mainloop()

三.EXE程序

压缩文件下载链接:https://github.com/a568972484/Random_roll_call

exe程序在压缩文件中dist文件中

四.相关实用文档

https://blog.csdn.net/weifuliu/article/details/82826643 #生成exe文件

https://www.cnblogs.com/ruo-li-suo-yi/p/7425307.html #grid设置位置参照

https://www.runoob.com/python/python-gui-tkinter.html #菜鸟变成关于tkinter概述

https://www.cnblogs.com/jxxclj/p/9572919.html #参考案例

https://blog.csdn.net/ppdyhappy/article/details/52129612 #打开文件

https://blog.csdn.net/qq_37235798/article/details/82349223 #控件

随机点名可视化界面,记录迟到人员,转exe文件的更多相关文章

  1. .Net轻松处理亿级数据--clickhouse及可视化界面安装介绍

    该篇内容由个人博客点击跳转同步更新!转载请注明出处! 前言 我是在17年就听说过Clickhouse,那时还未接触过亿数据的运算,那时我在的小公司对于千万数据的解决方案还停留在分库分表,最好的也是使用 ...

  2. java实现点名,并记录被点次数

    java实现点名,并记录被点次数 import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStrea ...

  3. 原生js实现简单的随机点名系统

    <!DOCTYPE html> <html lang="en"> <head>     <meta charset="UTF-8 ...

  4. java实现课堂随机点名小程序

    通过jdbc连接数据库实现读取学生花名册进行随机点名! ~jdbc连接mysql数据库  ||  注释部分代码可通过读取.txt文档实现显示学生信息 ~通过点击开始按钮实现界面中间标签不断更新学生信息 ...

  5. 随机点名小程序--- -JAVA版本

    话不多少,直接上代码 一个能够直接运行的随机点名的小程序,一个界面化的小程序.望广大网友多多支持! 1.创建一个随机点名的类 public class ProcessRandomName { JFra ...

  6. Python可视化界面

    可视化界面程序,本来不想写,只在console台运行就好,但是后来很多小伙伴都有这样的需求: 需要从redis中删除某个key的value,然后需要跟key去查,有些小伙伴不会用redis,就产生如下 ...

  7. TODO:从数据库中随机抽取一条记录

    TODO:从数据库中随机抽取一条记录 1.最直接,最粗暴的方法先计算记录的总数,然后选择一个从0到记录总数之间的随机数n,利用skip跳过n条记录,这是效率低下的的方法,首先的记录总数,在用skip会 ...

  8. 【转】oracle 中随机取一条记录的两种方法

    oracle 中随机取一条记录的两种方法 V_COUNT INT:=0; V_NUM INT :=0; 1:TBL_MYTABLE 表中要有一个值连续且唯一的列FID BEGIN SELECT COU ...

  9. js随机点名

    定时器案例. <!-- Author: XiaoWen Create a file: 2016-12-08 12:27:32 Last modified: 2016-12-08 12:51:59 ...

随机推荐

  1. 在Windows IoT上生成和识别二维码

    在Windows IoT生成和识别二维码,实际上由于是UWP上实现,所以,理论上,这些生成和识别二维码的方法也可以在其它平台上运行. 关于二维码的生成有很多库可以实现,比如QRCoder,这个库可以在 ...

  2. QML Settings 小的示例

    QML 中使用 Settings 可以保存一些简单的信息,例如用户名,密码,窗口位置,大小等,没有Sqlite那么麻烦,简单易用哦~~~(环境:Qt5.8  for android ,Windows ...

  3. 迁移到MSYS2 与 Qt 工具链注意的几个事情(g++在链接时,符号依赖项查找遵循从左至右的顺序,但qmake会自动合并造成错误。使用脚本给Mingw32-make创造出一个局部的VC编译环境)

    Microsoft Visual Studio 2015社区版提供了强大的开发体验,且 Qt 提供了预编译版本.然而,由于客户提出兼容Windows XP ~ Windows 8.1 这样宽泛的环境要 ...

  4. Globalize 1.0 发布,jQuery 的国际化插件

    分享 <关于我> 分享  [中文纪录片]互联网时代                 http://pan.baidu.com/s/1qWkJfcS 分享 <HTML开发MacOSAp ...

  5. CKEditor 4.5 beta 发布,可视化 HTML 编辑器

    分享 <关于我> 分享  [中文纪录片]互联网时代                 http://pan.baidu.com/s/1qWkJfcS 分享 <HTML开发MacOSAp ...

  6. C++ 使用回调函数的方式 和 作用。 持续更新

    先看两个demo: 一.在类test1中调用函数print() ,把print()的函数指针传递给test1的函数指针参数 test1.h: #include <stdio.h> #inc ...

  7. 教你做一个牛逼的DBA(在大数据下)

    一.基本概念 大数据量下,搞mysql,以下概念需要先达成一致 1)单库,不多说了,就是一个库 2)分片(sharding),水平拆分,用于解决扩展性问题,按天拆分表 3)复制(replication ...

  8. 系列教程 之 Android开发之旅

    工作室持续推出Android开发系列教程与案例,供广大朋友分享交流技术经验,帮助喜欢Android的朋友们学习进步: 1. Android开发之旅(1) 之 Android 开发环境搭建 代码之间工作 ...

  9. 实战Java的反射机制

    众所周知,Java要调用某个对象的方法首先需要对象实例化后才能调用. 而实例化对象常见的就是new执行和spring(DI)的依赖注入了. Spring的DI其实就是以反射作为最基础的技术手段. 一. ...

  10. Hive学习之路(一)—— Hive 简介及核心概念

    一.简介 Hive是一个构建在Hadoop之上的数据仓库,它可以将结构化的数据文件映射成表,并提供类SQL查询功能,用于查询的SQL语句会被转化为MapReduce作业,然后提交到Hadoop上运行. ...