文档章节

Python学习day1作业总结

ygqygq2
 ygqygq2
发布于 2016/11/20 12:06
字数 1428
阅读 39
收藏 0
点赞 0
评论 0
为了以后更好更快速的复习,此博客记录我对作业的总结。对于基础作业,我认为最重要的是过程,至于实现是不是完美,代码是不是完美,虽然重要,但是作业过程中,用到的知识点是值得总结和整理的。

一.模拟登陆:

1. 用户输入帐号密码进行登陆  
2. 用户信息保存在文件内  
3. 用户密码输入错误三次后锁定用户  

思路:

1)输入时用户名后,先判断用户名是否被锁,然后检查用户名是否存在用户数据库;  
2)输入相同不存在用户名3次,此用户名被锁;  
3)输入用户名存在时才可输入密码,相同用户名时,输入密码错误三次,此用户名被锁;  
4)若每次都没输入存在的用户,则再次要求输入用户,直到达到总输入次数;

基本流程图:

wKioL1gMPYDC8XOrAAHI3_mcZTE285.jpg

代码:

cat user_login.py #主程序
#!#!/usr/bin/env python
#_*_coding:utf-8_*_
'''
 * Created on 2016/10/10 22:13.
 * @author: Chinge_Yang.
'''
import os
import getpass
retry_max = 3
retry_count = 0
user_file = "user.txt"
lock_file = "user_lock.txt"
user_same = 0
user_tmp = ""
if not os.path.exists(lock_file):   #不存在时,则创建
    f = open(lock_file,'w')
    f.close()

while retry_count < retry_max:
    #输入用户名
    user_name = input("Please input your name:")
    #输入的用户名和上次输入的对比
    if user_name == user_tmp:
        #用户一样数加1
        user_same += 1
    else:
        #用户一样数归0
        user_same = 0
    #输入的用户名存为临时变量
    user_tmp = user_name
    #判断用户是否被锁
    lock_check = open(lock_file)
    for line in lock_check:
        line = line.split()
        #用户被锁,打印提示
        if user_name == line[0]:
            exit("User \033[1;31;40m%s\033[0m is locked!" % user_name)
    lock_check.close()
    #查看是否存在于用户数据库
    user_check = open(user_file)
    for l in user_check:
        l = l.split()
        user = l[0]
        passwd = l[1]
        if user_name == user:
            #输入密码
            #user_passwd = input("Please input your password:")
            user_passwd = getpass.getpass("\033[1;33;40mPlease input your password:\033[0m")
            #判断密码是否正确
            if user_passwd == passwd:
                exit("\033[1;32;40mWelcome to you!\033[0m")
            else:
                print("User \033[1;31;40m%s\033[0m password is error!" % user_name)
            #用户存在于数据库,跳出循环
            break
    else:
        print("User \033[1;31;40m%s\033[0m not match in the user file!" % user_name)
    user_check.close()
    if user_same >= 2:
        print("User \033[1;31;40m%s\033[0m name was locked!" % user_name)
        #将用户名写入到锁定文件中
        file = open(lock_file,"a")
        file.write(user_name+"\n")
        file.close()
    retry_count += 1

user.txt文件内容格式:

cat user.txt
apache 123
jim 234
docker 333
fank yhn

总结:

1.getpass模板用于输入密码时,不显示明文;

2.os.path.exists(文件路径)用于判断文件是否存在;

3.input的用法,版本3,默认输入的内容是字符类型,如果是变量名,则为此变量名的数据类型;

4.if判断语句用法;

5.while循环语句用法;

6.split()指定分隔符对字符串切片用法;

7.print(“%s” % name)等格式化输出;

8.颜色输出用法:手打出来 \033[32;1m内容\033[0m ;

9.数学算法使用;

二.三级菜单:

1. 运行程序输出第一级菜单  
2. 选择一级菜单某项,输出二级菜单,同理输出三级菜单  
3. 菜单数据保存在文件中

思路:

1.菜单数据使用字典保存在文件中,使用import读取;

2.获取一级菜单;

3.获取二级菜单;

4.获取三级菜单;

5.使用循环打印菜单;

基本流程图:

image

代码:

cat Three_layer_menu.py #主程序
#!/usr/bin/env python
#_*_coding:utf-8_*_
'''
 * Created on 2016/10/16 21:31.
 * @author: Chinge_Yang.
'''
import sys
import menu
while True:
    #定义一层菜单为字典
    one_dict = {}
    #获取字典所有的键
    one_layer = menu.menu.keys()
    #获取字典所有的枚举
    one_enu = enumerate(one_layer)
    #一层菜单字典
    for index1,value1 in one_enu:
        one_dict[index1]=value1
    for k1 in one_dict:
        print ("\033[32m%d\033[0m --> %s" %(k1,one_dict[k1]))
    print ("输入【back】:返回;【quit】:退出")
    once_select = input("请输入你的选择:\n").strip()
    if once_select.isdigit():
        once_select = int(once_select)
        if 0 <= once_select < len(one_dict):
            print("---->进入一级菜单 \033[32m%s\033[0m" %(one_dict[once_select]))
            while True:
                #定义二层菜单为字典
                two_dict = {}
                # 获取字典所有的键
                two_layer = menu.menu[one_dict[once_select]].keys()
                # 获取字典所有的枚举
                two_enu = enumerate(two_layer)
                # 二层菜单字典
                for index2, value2 in two_enu:
                    two_dict[index2] = value2
                # 打印二层菜单
                for k2 in two_dict:
                    print("\033[32m%d\033[0m --> %s" % (k2, two_dict[k2]))
                print("输入【back】:返回;【quit】:退出")
                twice_select = input("请输入你的选择:\n").strip()
                if twice_select.isdigit():
                    twice_select = int(twice_select)
                    if 0 <= twice_select < len(two_dict):
                        print("---->进入二级菜单 \033[32m%s\033[0m" % (two_dict[twice_select]))
                        # 定义三层菜单列表
                        three_layer = menu.menu[one_dict[once_select]][two_dict[twice_select]]
                        while True:
                            # 打印三层菜单
                            for k3 in three_layer:
                                print (k3)
                            print ("输入【back】:返回;【quit】:退出")
                            three_select = input("请输入你的选择:\n").strip()
                            if three_select == "back":
                                break
                            elif three_select == "quit":
                                sys.exit ("----谢谢使用----")
                            continue
                else:
                    if twice_select == "back":
                        break
                    elif twice_select == "quit":
                        sys.exit ("----谢谢使用----")
                    print ("\033[31m请输入数字\033[0m")
        else:
            print("----\033[31m数字超出范围,请重新输入!\033[0m----")
    else:
        if once_select == "back":
            break
        elif once_select == "quit":
            sys.exit ("----谢谢使用----")
        print ("\033[31m请输入数字\033[0m")
cat menu.py
#!/usr/bin/env python  
# _*_coding:utf-8_*_  
'''  
* Created on 2016/10/16 19:37.  
* @author: Chinge_Yang.  
'''
menu = {  
    "家用电器": {  
        "电视": [  
            "合资品牌电视",  
            "国产品牌电视",  
            "互联网品牌电视"  
        ],  
        "空调": [  
            "壁挂式空调",  
            "柜式空调",  
            "中央空调",  
            "空调配件"  
        ],  
        "洗衣机": [  
            "滚筒洗衣机",  
            "洗烘一体机",  
            "波轮洗衣机",  
            "迷你洗衣机",  
            "洗衣机配件"  
        ]  
    },  
    "电脑": {  
            "电脑整机": [  
                "笔记本",  
                "游戏本"  
                "平板电脑",  
                "平板电脑配件",  
                "台式机",  
                "一体机服务器",  
                "笔记本配件"  
            ],  
            "电脑配件": [  
                "显示器",  
                "CPU",  
                "主板",  
                "硬盘",  
                "内存"  
            ],  
            "外设产品": [  
                "鼠标",  
                "键盘",  
                "键鼠套装",  
                "网络仪表仪器",  
                "U盘",  
                "移动硬盘"  
            ]  
        }  
    }

总结:

1.字典的用法,包括获取key,value及相关函数用法;

2.列表的用法,遍历列表的用法;

3.import导入py文件用法;

本文出自 “ygqygq2” 博客,谢绝转载!

本文转载自:http://ygqygq2.blog.51cto.com/1009869/1864705

共有 人打赏支持
ygqygq2
粉丝 0
博文 12
码字总数 9366
作品 0
珠海
程序员
连 00 后学 Python 了,身为程序员的我慌了

2018 年 1 月 16 日,教育部召开新闻发布会,正式将人工智能、物联网、大数据处理划入高中新课标,并于今年秋季开始执行。这意味着,现在 16 岁的学生就要开始学习编程了! 本次核心目标:修...

dqcfkyqdxym3f8rb0 ⋅ 05/06 ⋅ 0

分享一些关于数据分析的学习资料

时间过得真快,转眼一周又要过去了。这一周里你读了什么书?学到了什么知识?有什么收获? 这周里,我收集到一些关于Python数据分析的学习资料,在这里一并分享给大家: Python数据分析班升级...

爱吃西瓜的番茄酱 ⋅ 05/13 ⋅ 0

他学习一年Python找不到工作,大佬都说你别再学Python了!

都说,滴水穿石非一日之功。然而有些人即使奋斗一辈子也比不上别人一年,别人学习一年比不得你学习一个月。其中缘由,有些人看了大半辈子还没看明白。 即使Python这么火,为何你学习一年的P...

柯西带你学编程 ⋅ 06/06 ⋅ 0

为什么Python成了开发AI的主流语言?Java系列、Ruby等编程语言不行吗?

导读 说道开发AI的语言,很多人说,不是Python吗?没错,Python是可以开发AI,但是不知道你们有没有想过,真的就只有Python才可以开发AI吗? 其实,像Java、Ruby也是开发AI很好的选择,但是为...

柯西带你学编程 ⋅ 05/29 ⋅ 0

Python进阶系列连载(13)——Python内置高阶函数filter(下)

前言 进阶部分连载继续~ 如果还没看过我的入门连载部分,先看: https://ask.hellobi.com/blog/wangdawei/10288 当然,小编的免费入门课程已经有咯,看过连载的朋友可以看看视频再快速梳理一...

ID王大伟 ⋅ 04/28 ⋅ 0

python学习--DAY2

程序1:name=“ (name) 出现错误: C:Python36python.exe C:/Users/XX/PycharmProjects/S23/DAY1/VAR.py File "C:/Users/XX/PycharmProjects/S23/DAY1/VAR.py", line 2 name=:“你好,世界”......

笨贼XX ⋅ 2017/06/16 ⋅ 0

IT届各位大佬告诉你,为什么学习AI之前要学习Python!

在之前的全国高中信息“新课标”出炉!要想报考这些专业,必须得会……中,我们从政策上给大家阐述了为什么要学Python。今天,我们就来听听IT届各位大佬是怎么说的。 编程是一项社交活动。 ...

python达人 ⋅ 04/30 ⋅ 0

Python、Lua和Ruby三大语言脚本哪家强?

这三种语言中的哪一种更合适你的项目?很大程度取决于你想达到什么样的目标。作为一书的结尾,在这一节里,我会描述一下它们各自的优点和不足。 Python的优点和不足 Python的优点如下: 1. P...

柯西带你学编程 ⋅ 06/01 ⋅ 0

荐书丨确认过眼神,这份Python书单一定是你的菜

点击上方“程序人生”,选择“置顶公众号” 第一时间关注程序猿(媛)身边的故事 Python 是军刀型的开源工具,被广泛应用于Web 开发、爬虫、数据清洗、自然语言处理、机器学习和人工智能等方...

csdnsevenn ⋅ 05/05 ⋅ 0

老司机工作总结!零基础python小白学习编程一定要知道的那些技巧

今天又是一年一度的关键时刻:高考了。高考可谓是牵动着无数普通家庭的心。但是高考就是千军万马过独木桥,是一场没有硝烟的战争,有输有赢。可是高考跟战争不一样的是,高考就算失败也会有其...

Python学习 ⋅ 06/07 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

从方法论到零售客户实践 解码阿里巴巴数据中台——2018上海云栖大会

摘要: 一、数据中台之道 6月8日,上海云栖大会进入了第二天的议程,数据中台专场论坛座无虚席,数据中台总架构师邓中华女士向在场的观众介绍了数据中台的衍生发展之道。 基于OneID、OneData...

阿里云云栖社区 ⋅ 23分钟前 ⋅ 0

Ubuntu部署django问题汇总

使用Anaconda3的Python3.6的pip安装UWSGI报错 原因是gcc版本不兼容,安装4.7并修改gccsudo apt-get install gcc-4.7sudo mv /usr/bin/gcc /usr/bin/gcc.baksudo ln -s /usr/bin/gcc-4.......

wuyaSama ⋅ 27分钟前 ⋅ 0

从方法论到零售客户实践 解码阿里巴巴数据中台——2018上海云栖大会

摘要: 一、数据中台之道 6月8日,上海云栖大会进入了第二天的议程,数据中台专场论坛座无虚席,数据中台总架构师邓中华女士向在场的观众介绍了数据中台的衍生发展之道。 基于OneID、OneData...

猫耳m ⋅ 27分钟前 ⋅ 0

Docker减肥小记

如果经常使用 docker,你会发现 docker 占用的资源膨胀很快,其中最明显也最容易被察 如何快速的清理 docker 占用的系统资源,具体点说就是删除那些无用的镜像、容器、网络和数据卷… 1、查看...

寰宇01 ⋅ 37分钟前 ⋅ 0

微信小程序中如何使用WebSocket实现长连接(含完整源码)

本文由腾讯云技术团队原创,感谢作者的分享。 1、前言 微信小程序提供了一套在微信上运行小程序的解决方案,有比较完整的框架、组件以及 API,在这个平台上面的想象空间很大。腾讯云研究了一...

JackJiang- ⋅ 45分钟前 ⋅ 0

定制库到Maven本地资源库

1.如果只有定制库的JAR文件 下载链接如下:pdf.jar 2.使用命令转换成Maven本地资源 mvn install:install-file -Dfile=/Users/manager/Downloads/clj-pdf-2.2.33.jar -DgroupId=clj-pdf -Dar......

年少爱追梦 ⋅ 49分钟前 ⋅ 0

高仿springmvc之xuchen-mvc

package org.mvc.framework.servlet; import java.io.BufferedReader; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.File; import java.io.......

徐志 ⋅ 52分钟前 ⋅ 0

关于自定义URLStreamHandler的一次踩坑

关于自定义URLStreamHandler的一次踩坑 20180625 lambo init 说明 一般自定义实现url的协议解析.方案为实现URLStreamHandler.实现其 openConnection 就可以了, 如果我们执行 new URL("xx://...

林小宝 ⋅ 53分钟前 ⋅ 0

【SM2证书】利用BC的X509v3CertificateBuilder组装X509国密证书

演示证书文件 链接: https://pan.baidu.com/s/1ijHNnMQJj7jzW-jXEVd6Gg 密码: vfva 所需jar包 <!-- https://mvnrepository.com/artifact/org.bouncycastle/bcpkix-jdk15on --> <dependenc......

小帅帅丶 ⋅ 54分钟前 ⋅ 0

用Calendar 实现 计算 一段时间的毫秒值

Calendar c=Calendar.getInstance();c.add(Calendar.MONTH, -1);int lastMonthMaxDay=c.getActualMaximum(Calendar.DAY_OF_MONTH);c.set(c.get(Calendar.YEAR), c.get(Calendar.MONTH)......

岸芷汀兰 ⋅ 57分钟前 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部