猜年龄,有三次机会,如何做?

  1. 检查 输入的数据是否合法,通过异常try来处理,并记录 输入错误次数

  2. 通过累加器,判断是否猜了3次,并提示还剩余多少的机会

  3. 当3次错误,跳出

#!/usr/bin/python3

def guess_age(name, real_age):
'''猜年龄,有三次机会'''
count = 0
print('%s来猜猜我的年龄来' % name)
while True:
error_number = 0
while True: # 验证是否输入合法 try:
maybe_age = int(input("%s:" % name))
except:
error_number += 1
print('调皮,不想玩了,已经答非所问 %s 次了' % error_number)
else:
break count += 1
if maybe_age == real_age:
if count == 1:
print('%s真的太棒了,居然马上就猜中了' % name)
else:
print('%s真的太ben了,居然猜了这么多次才猜中,你居然猜了 %s 次' % (name, count))
break
elif maybe_age > real_age:
print('我有那么老么?滚滚滚,再给你%d机会'%(3-count))
elif count == 3:
print('不和你玩了,真的ben!!!!!!!')
break
elif maybe_age < real_age:
print('嗯哼,把我年龄说的那么低,暗示我智商低?哼,还给你%d机会' % (3-count)) if __name__ == '__main__':
guess_age(name='北门吹雪', real_age=18)

  猜年龄进阶

    猜年龄,并且记录最近5次猜的数据,并保存下来,下次打开程序,历史记录依旧保存

#!/usr/bin/python3

import pickle
import os
from random import randint
from collections import deque def guess_age(age): # 判断输入是否合法
try:
age = int(age)
except:
print('输入错误,重新输入')
return 'error'
if age == real_age:
print('猜对了')
return 'ok'
elif age > real_age:
print('猜大了')
return None
elif age < real_age:
print('猜小了')
return None if __name__ == '__main__':
# 判断历史记录是否存在
if os.path.exists('history'):
try:
# 存在就打开
history = pickle.load(open('history', 'br'))
except:
# 打开失败或者损坏重新定义
history = deque([], 5)
else:
# 不存在声明新的q,[]表示初始列表,5表示长度
history = deque([], 5)
# 生成随机数
real_age = randint(1, 100)
while True:
age = input('(1~100)输入:')
# 查询历史命令
if age == 'history' or age == 'h?':
print(list(history))
continue
result = guess_age(age)
history.append(age)
# 判断是否猜对
if result == 'ok':
break
# 退出程序
if age == 'q':
break
# 把历史数据写入文件
pickle.dump(history, open('history', 'bw'))

python_猜年龄的更多相关文章

  1. 我的python中级班学习之路(全程笔记第一模块) (第一章)(第2部分:如何设置python中的字体颜色,猜年龄练习题解答,while else语句,pycharm的使用)

    第一章:  python 基础语法 第  2  部分: 一.猜年龄练习题解答 直接上代码 >>> age = 26 >>> count = 0 >>&g ...

  2. python 小程序,猜年龄

    要求如下:

  3. 基于虹软 2.0 人脸识别猜年龄 java版 demo

    首先感谢虹软,是你们提供这么好的SDK支撑了我们的想象力! 这是一个用javav编写的可视化应用,用户通过自己的脸和计算机进行交互,计算机则通过萌萌女孩的语音和用户对话.核心程序就是利用ArcFace ...

  4. {python}完成完整的温度转换程序 猜数字游戏(猜价格,猜年龄等) 解析身份证号、学号不同片段的含义

    完成完整的温度转换程序 while True: a = int(input("如果是华氏转摄氏,请按1\n,如果是摄氏转华氏,请按2\n")) if a==1: h = float ...

  5. Python练习-猜年龄的LowB游戏

    Alex大神今天让我做一个猜年龄的游戏: 第一个游戏是你只能猜三次:真的很LowB啊~ # 编辑者:闫龙 #猜年龄游戏,3次后程序自动退出! ages = 29; #for循环3次 for i in ...

  6. python基础代码(猜年龄、从最内层跳出多层循环、简单的购物车程序)

    1.猜年龄 , 可以让用户最多猜三次! age = 55 i=0 while i<3: user_guess = int (input ("input your guess:" ...

  7. day03_11 if语句实现猜年龄01

    老男孩猜年龄游戏 age_of_princal = 56 guess_age = int( input(">>:") ) #以下为伪代码 ''' if guess_ag ...

  8. python猜年龄游戏升级版

    猜年龄游戏升级版 要求:允许用户最多尝试3次,每尝试3次后,如果还没猜对,就问用户是否还想继续玩,如果回答Y,就继续让其猜3次,以此往复,如果回答N,就退出程序,如何猜对了,就直接退出 age = 1 ...

  9. 用python写了一个猜年龄小游戏

    写一个猜年龄游戏: 需要实现用户登录的功能 初始用户登录信息为 {'hades': '13579','nick': '123','ruixing': 'a1','fanping': 'b2'} 登录时 ...

随机推荐

  1. Java学习笔记15(面向对象八:匿名对象、内部类)

    匿名对象: 是指创建对象的时候,只有创建对象的语句,却没有把对象地址值赋给某个变量 创建一个普通对象: Person p = new Person(); 创建一个匿名对象: new Person(); ...

  2. 【扩展欧几里得】NOIP2012同余方程

    题目描述 求关于 x 的同余方程 ax ≡ 1 (mod b)的最小正整数解. 输入输出格式 输入格式: 输入只有一行,包含两个正整数 a, b,用一个空格隔开. 输出格式: 输出只有一行,包含一个正 ...

  3. windows第四层负载均衡--基于NLB负载均衡

    上面有一篇文章说windows第七层负载均衡,这次讲讲第四层负载均衡 TCP/IP协议族,第七层是应用层,第四层是传输层.第四层负载均衡主要通过IP进行转化. 一些优秀的第四层负载均衡软件,速度可以接 ...

  4. C#学习笔记-工厂模式

    题目:计算器 解析:工厂方法(Factory Method),定义一个用于创建对象的接口,让子类决定实例化哪一个类. 定义运算类: class Operation { ; ; public doubl ...

  5. JAVA进阶--ThreadPoolExecutor机制

    ThreadPoolExecutor机制 一.概述 1.ThreadPoolExecutor作为java.util.concurrent包对外提供基础实现,以内部线程池的形式对外提供管理任务执行,线程 ...

  6. 【Core2.0帮助类】

    缓存帮助类(CacheHelper) /// <summary> /// 缓存帮助类 /// </summary> public class CacheHelper {//下载 ...

  7. TCP/IP(三)数据链路层~1

    前言 其实前面一堆讲的物理层的概念,会感觉特别的难理解,因为这是一个非常强大的计算机网络体系的底层知识,没有关系!我们大致了解一下就行了. 一.数据链路层概述 这是百度的简介 看图:理解一下,数据链路 ...

  8. HUST 1555 A Math Homework

    1555 - A Math Homework 时间限制:1秒 内存限制:128兆 338 次提交 131 次通过 题目描述     QKL is a poor and busy guy, and he ...

  9. HDU2243 考研路茫茫――单词情结

    Description 背单词,始终是复习英语的重要环节.在荒废了3年大学生涯后,Lele也终于要开始背单词了. 一天,Lele在某本单词书上看到了一个根据词根来背单词的方法.比如"ab&q ...

  10. [51nod1673]树有几多愁

    lyk有一棵树,它想给这棵树重标号. 重标号后,这棵树的所有叶子节点的值为它到根的路径上的编号最小的点的编号. 这棵树的烦恼值为所有叶子节点的值的乘积. lyk想让这棵树的烦恼值最大,你只需输出最大烦 ...