'''
面向过程编程 核心过程二字,过程指的是解决问题的步骤,即先干什么、再干什么、然后干什么... 基于该思想编写程序就好比在设计一条流水线,是一种机械式的思维方式优点
复杂的问题流程化、进而简单化 缺点 扩展性极差'''
# 接收用户输入用户名,进行用户名合法性校验,拿到合法的用户名
def check_user(): while True: name = input('username>>').strip() if name.isalpha(): return name else: print('用户名必须为字母,傻叉')# 接收用户输入密码,进行密码合法性校验,拿到合法的密码
def check_pwd(): while True: pwd1=input('password>>: ').strip() if len(pwd1) < 5: print('密码的长度至少5位') continue pwd2=input('again>>: ').strip() if pwd1 == pwd2: return pwd1 else: print('两次输入的密码不一致')def check_age():
pass# pwd=check_pwd()
# print(pwd)# 将合法的用户名与密码写入文件def insert(user,pwd,age,path='db.txt'): with open(path,mode='a',encoding='utf-8') as f: f.write('%s:%s:%s\n' %(user,pwd,age))def register():
user=check_user() pwd=check_pwd() age=check_age() insert(user,pwd,age) print('register successfull')register()
# 用户功能层
def register(): while True: # 检测用户名 name=input('username>>: ').strip() #检测用户是否重复,如果重复了则重新输入,否则break res=check_user_interface(name) if res: print('用户存在') else: breakwhile True: # 检测密码
pwd1 = input('pwd1>>: ').strip() pwd2 = input('pwd2>>: ').strip() if pwd1 != pwd2: print('两次输入密码不一致,重新输入') else: breakdef tell_info(): name=input('>>: ').strip() info=select(name) print(info)
# 接口层
def check_user_interface(name): res = select(name) # res=['egon','123'] if res: return True else: return False # 数据处理层def select(name): with open('db.txt', 'r', encoding='utf-8') as f: for line in f: info = line.strip('\n').split(':') #info=['egon','123'] if name == info[0]: return info1、什么是模块模块是一系列功能的集合体 import spam 在import 后面跟上自己自定义文件名 运用的时候是spam.x span.是前缀,.x后面的是属性,指挥在他自己的模块里找如果import 后面跟的文件名过长,也可以通过as 起别名常见的模块形式(自定义模块,第三方模块,内置模块):(内置模块是C语言内置功能,因为python解释器是C语言编写的) 1、一个py文件就是一个模块,文件名是module.py,而模块名是module. 2、一个包含有__init__.py文件的文件夹也是模块 3、已被编译为共享库或DLL的C或C++扩展 4、使用C编写并链接到python解释器的内置模块2、为什么要用模块 1、用第三方或者内置的模块是一种拿来主义,可以极大地提升开发效率 2、自定义模块将我们自己程序中需要用到的公共的功能写入一个python文件 然后程序的各部分组件,可以通过导入的方式来引用、重用自定义模块中的功能3、如何用模块 导入的方式有两种 import 模块名 from 模块名 inport 具体的功能
# 当前的执行文件# x=1# y=2# 首次导入模块发生了3件事:#1、导入模块时以模块为准创造一个模块的名称空间 #2、执行模块对应的文件,将执行过程中产生的名字都丢到模块的名称空间#3、在当前执行文件中拿到一个模块名# import spam # 之后的重复导入会直接引用之前创造好的结果,不会重复执行模块的文件# import spam #spam=spam=模块名称空间的内存地址
# spam.名字
# print(x)# spam.x# print(spam.money)# print(spam.read1)# print(spam.read2)# print(spam.change)# money=11111111111111# spam.read1()# def read1():# print('执行文件的read1')# spam.read2()# spam.change()
# print(spam.money)# print(money)# import spam as sm
# print(sm.money)# import time,spam,os,sys
# import spam# import os# import sys # import spam# spam.money# from ... import ...首次导入也发生了三件事:
#1、以模块为准创造一个模块的名称空间#2、执行模块对应的文件,将执行过程中产生的名字都丢到模块的名称空间#3、在当前执行文件的名称空间中拿到一个名字,该名字直接指向模块中的某一个名字,意味着可以不用加任何前缀而直接使用 文件搜索模块:导入模块时查找模块的顺序是:内存---内置-----环境变量如果文件在当前文件外,可以通过两种方式查找到:1、是调用sys内置模块,然后通过sys.path.append(r"地址")2、from 目录文件 import 模块名如果文件在当前文件的子文件内,可以通过from 子文件名 import 模块名# x=1
# y=2## from spam import money,read1# money=10# print(money)# print(read1)# from .... import ... 对比 import 。。。
# 优点:不用加前缀,代码更为精简# 缺点:容易与当前执行文件中名称空间中的名字冲突# 相同点:
# 1、都会执行模块对应的文件,都会产生模块的名称空间# 2、调用功能时,需要跑到定义时寻找作用域关系,与调用位置无关# 不同点# 1、一种需要加前缀,一种不需要加前缀 # from spam import money,read1,read2,change# money=111111111111111111# read1()# def read1():# print('当前执行文件的read1',money)# read1()
# def read1():
# print('当前执行文件的read1',money)# read2()
# change=1
# change()# print(money) # from spam import money# from spam import read1# from spam import read2# from spam import changefrom spam import *
print(money)print(read1)print(change)
# print(read2)