【第035讲心得】【Easygui安装和简单的图形界面小游戏】
本帖最后由 heidern0612 于 2020-3-30 16:21 编辑写心得的过程都是自我思考的过程,借鉴了很多论坛前辈大神们的经验,如有疏漏或错误,恳请指出,不胜感激。
1、安装easygui PS:此方法适用于安装别的类型库,如Pygame等。
A、python自行下载(推荐)
方便,省事,不用你找下载地址。
win徽标键+R打开运行框,运行里输入cmd进入dos界面,定位到你python根目录的Scripts目录里。
指令安装运行:pip install easygui,程序会自动从网上搜集下载最新的easygui到你的电脑上。
安装完毕后import easygui已经可以使用。
比较推荐这种做法。
如果PIP安装的时候总是提示链接超时,请看这个帖子戳我前进
B、官方下载
猛击我跳转官方下载
进入后点击绿色的那个长条,最新版本下载:
跳转下载页面,五秒钟后自动下载。
下载完毕后解压文件到任意盘的根目录,把解压后的文件名改个好记得名字,如easygui。
执行里面的setup(用你的IDLE打开),执行安装。
2、easygui的基本用法
小甲鱼老师总结了一篇,戳我跳转
我这里自己网上扒了两篇,也挺好。
戳我跳转1
戳我跳转2
不详细介绍了,太长。组合可以达到一定的简单效果,标准的乐高玩具模组。
3、课后习题解析:
import random
import easygui as g
g.msgbox("嗨,欢迎进入第一个界面小游戏^_^")
secret = random.randint(1,10)
msg = "不妨猜一下小甲鱼现在心里想的是哪个数字(1~10):"
title = "数字小游戏"
guess = g.integerbox(msg, title, lowerbound=1, upperbound=10)
while True:
if guess == secret:
g.msgbox("我草,你是小甲鱼心里的蛔虫吗?!")
g.msgbox("哼,猜中了也没有奖励!")
break
else:
if guess > secret:
g.msgbox("哥,大了大了~~~")
else:
g.msgbox("嘿,小了,小了~~~")
guess = g.integerbox(msg, title, lowerbound=1, upperbound=10)
g.msgbox("游戏结束,不玩啦^_^")
这里使用了integerbox这个参数。
使用方法和解释:
integerbox(msg='', title=' ', default=None, lowerbound=0, upperbound=99, image=None, root=None)
integerbox() 为用户提供一个简单的输入框,用户只能输入范围内(lowerbound 参数设置最小值,upperbound 参数设置最大值)的整型数值,否则会要求用户重新输入。
import easygui as g
msg = "请填写以下联系方式"
title = "账号中心"
fieldNames = [" *用户名", " *真实姓名", "固定电话", " *手机号码", "QQ", " *E-mail"]
fieldValues = []
fieldValues = g.multenterbox(msg,title, fieldNames)
while 1:
if fieldValues == None:
break
errmsg = ""
for i in range(len(fieldNames)):
option = fieldNames.strip()
if fieldValues.strip() == "" and option == "*":
errmsg += ('【%s】为必填项。\n\n' % fieldNames)
if errmsg == "":
break
fieldValues = g.multenterbox(errmsg, title, fieldNames, fieldValues)
print("用户资料如下:%s" % str(fieldValues))
这里使用了multenterbox这个参数。
使用方法和详解:
multenterbox(msg='Fill in values for the fields.', title=' ', fields=[], values=[], callback=None, run=True)
multenterbox() 为用户提供多个简单的输入框,要注意以下几点:
如果用户输入的值比选项少的话,则返回列表中的值用空字符串填充用户为输入的选项。
如果用户输入的值比选项多的话,则返回的列表中的值将截断为选项的数量。
如果用户取消操作,则返回域中的列表的值或者 None 值。
import easygui as g
import os
file_path = g.fileopenbox(default="*.txt")
with open(file_path) as f:
title = os.path.basename(file_path)
msg = "文件【%s】的内容如下:" % title
text = f.read()
g.textbox(msg, title, text)
这里使用了fileopenbox这个参数。
使用方法和详细解释:
fileopenbox(msg=None, title=None, default='*', filetypes=None, multiple=False)
fileopenbox() 函数用于提供一个对话框,返回用户选择的文件名(带完整路径哦),如果用户选择 “Cancel” 则返回 None。
import easygui as g
import os
file_path = g.fileopenbox(default="*.txt")
with open(file_path) as old_file:
title = os.path.basename(file_path)
msg = "文件【%s】的内容如下:" % title
text = old_file.read()
text_after = g.textbox(msg, title, text)
if text != text_after[:-1]:
# textbox 的返回值会追加一个换行符
choice = g.buttonbox("检测到文件内容发生改变,请选择以下操作:", "警告", ("覆盖保存", "放弃保存", "另存为..."))
if choice == "覆盖保存":
with open(file_path, "w") as old_file:
old_file.write(text_after[:-1])
if choice == "放弃保存":
pass
if choice == "另存为...":
another_path = g.filesavebox(default=".txt")
if os.path.splitext(another_path) != '.txt':
another_path += '.txt'
with open(another_path, "w") as new_file:
new_file.write(text_after[:-1])
下面这个代码量有点大,建议从下往上看,思路比较清晰。
分析佳宇老师思路:
1、通过serch_file函数查找当前目录下是否存在traget扩展名文件;
2、存在的话,serch_file函数调用calc_code函数统计文件行数;统计完的数值赋值给变量lines;
3、文件的类型和源代码行数的数量根据ext的存在而变化。调用递归,搜索上一层。
4、调用show_result显示打印结果。
import easygui as g
import os
def show_result(start_dir):
lines = 0
total = 0
text = ""
for i in source_list:
lines = source_list #i的结果是ext类型结果的自增lines
total += lines #total的结果是souce_list中所有元素的合
text += "【%s】源文件 %d 个,源代码 %d 行\n" % (i, file_list, lines)
title = '统计结果'
msg = '您目前共累积编写了 %d 行代码,完成进度:%.2f %%\n离 10 万行代码还差 %d 行,请继续努力!' % (total, total/1000, 100000-total)
g.textbox(msg, title, text)
def calc_code(file_name):
lines = 0
with open(file_name) as f:
print('正在分析文件:%s ...' % file_name)
try:
for each_line in f:
lines += 1
except UnicodeDecodeError:
pass # 不可避免会遇到格式不兼容的文件,这里忽略掉......
return lines
def search_file(start_dir) :
os.chdir(start_dir)
for each_file in os.listdir(os.curdir) :
ext = os.path.splitext(each_file) #当前目录存在文件的扩展名
if ext in target : #如果ext在target字典中。
lines = calc_code(each_file) # 调用cale_code函数进行统计行数
# 还记得异常的用法吗?如果字典中不存,抛出 KeyError,则添加字典键
# 统计文件数
try:
file_list += 1 #文件数自增1
except KeyError:
file_list = 1
# 统计源代码行数
try:
source_list += lines #行数自增lines,lines来源自calc_code函数
except KeyError:
source_list = lines
if os.path.isdir(each_file) : #如果当前搜索的是个目录:
search_file(each_file) # 递归调用
os.chdir(os.pardir) # 递归调用后切记返回上一层目录,避免显示空目录和死循环,往上一层搜索。
target = ['.c', '.cpp', '.py', '.cc', '.java', '.pas', '.asm']
file_list = {}
source_list = {}
g.msgbox("请打开您存放所有代码的文件夹......", "统计代码量")
path = g.diropenbox("请选择您的代码库:")
search_file(path)
show_result(path)
第一个方法好! 为什么用第一个方法,它总是显示 'pip' 不是内部或外部命令,也不是可运行的程序或批处理文件。
绵绵haha 发表于 2020-4-16 10:21
为什么用第一个方法,它总是显示 'pip' 不是内部或外部命令,也不是可运行的程序或批处理文件。
可能是没勾东西,这个状况重新安装python然后把勾全打上就好了
页:
[1]