|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 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[i].strip()
- if fieldValues[i].strip() == "" and option[0] == "*":
- errmsg += ('【%s】为必填项。\n\n' % fieldNames[i])
- 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)[1] != '.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] #i的结果是ext类型结果的自增lines
- total += lines #total的结果是souce_list中所有元素的合
- text += "【%s】源文件 %d 个,源代码 %d 行\n" % (i, file_list[i], 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)[1] #当前目录存在文件的扩展名
- if ext in target : #如果ext在target字典中。
- lines = calc_code(each_file) # 调用cale_code函数进行统计行数
- # 还记得异常的用法吗?如果字典中不存,抛出 KeyError,则添加字典键
- # 统计文件数
- try:
- file_list[ext] += 1 #文件数自增1
- except KeyError:
- file_list[ext] = 1
- # 统计源代码行数
- try:
- source_list[ext] += lines #行数自增lines,lines来源自calc_code函数
- except KeyError:
- source_list[ext] = 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)
复制代码
|
评分
-
查看全部评分
|