选课系统:

角色:学校、学员、课程、讲师

要求:

1. 创建北京、上海 2 所学校

2. 创建linux , python , go 3个课程 , linux\py 在北京开, go 在上海开

3. 课程包含,周期,价格,通过学校创建课程

4. 通过学校创建班级, 班级关联课程、讲师

5. 创建学员时,选择学校,关联班级

5. 创建讲师角色时要关联学校,

6. 提供两个角色接口

6.1 学员视图, 可以注册, 交学费, 选择班级,

6.2 讲师视图, 讲师可管理自己的班级, 上课时选择班级, 查看班级学员列表 , 修改所管理的学员的成绩

6.3 管理视图,创建讲师, 创建班级,创建课程

7. 上面的操作产生的数据都通过pickle序列化保存到文件里

README学校选课系统

学生视图:可以自助注册,注册时可以选择班级,通过注册名登陆,,交学费,上课

讲师视图:通过讲师编号登陆,可以管理自己的班级,上课时选择班级, 查看班级学员列表 , 修改所管理的学员的成绩

管理视图: 1、创建学校. 2、查看学校.

3、创建班级. 4、查看班级.

5、创建讲师. 6、查看讲师.

7、创建课程. 8、查看课程.

9、课师关联. 10、查看课师关联.

11、创建学员. 12、查看学员.

程序结构:

school/#程序目录

|- - -__init__.py

|- - -bin/#启动目录

| |- - -__init__.py

| |- - -admin.py#管理视图启动

| |- - -initalize.py#系统初始化

| |- - -stud.py#学生视图启动

| |- - -teacher.py#讲师视图启动

|

|- - -cfg/#配置目录

| |- - -__init__.py

| |- - -config.py#配置文件

|

|- - -core/#主要程序目录

| |- - -__init__.py

| |- - -admin_main.py#管理视图主逻辑

| |- - -class_main.py#主逻辑,类

| |- - -func_main.py#主逻辑,函数

| |- - -id_classes.py#id文件主逻辑,函数

| |- - -log_file.py#日志函数

| |- - -students_main.py#学生视图主逻辑

| |- - -teacher_main.py#讲师视图主逻辑

|

|- - -db/#数据目录

| |- - -__init__.py

| |- - -admin_file/#管理员相关文件

| | |- - -

| |

| |- - -admin_user_list#是否初始化的检测文件

| |

| |- - -classes/#班级文件目录

| |- - -course/#课程文件目录

| |- - -school/#学校文件目录

| |- - -students_file/#学生文件目录

| |- - -teac_to_cour/#讲师与课程关联文件目录

| |- - -teacher_file/#讲师文件目录

|

|

|- - -log/#日志目录

| |- - -__init__.py

详细代码:

admin.py

1 #!usr/bin/env python 2 #-*-coding:utf-8-*- 3 # Author calmyan 4 5 6 #管理视图:创建讲师, 创建班级,创建课程 7 8 import os ,sys 9 BASE_DIR=os.path.dirname(os.path.dirname(os.path.abspath(__file__)))#获取相对路径转为绝对路径赋于变量10 sys.path.append(BASE_DIR)#增加环境变量11 #print(BASE_DIR)12 from core import admin_main #包含目录下的文件脚本13 if __name__ == '__main__':14 admin_main.loging()View Code

initalize.py

1 #!usr/bin/env python 2 #-*-coding:utf-8-*- 3 # Author calmyan 4 #初始化系统 5 import os ,sys 6 BASE_DIR=os.path.dirname(os.path.dirname(os.path.abspath(__file__)))#获取相对路径转为绝对路径赋于变量 7 sys.path.append(BASE_DIR)#增加环境变量 8 from core import func_main 9 if __name__ == '__main__':10 func_main.initialize_admin()#初始化管理员View Code

stud.py

1 #!usr/bin/env python 2 #-*-coding:utf-8-*- 3 # Author calmyan 4 import os ,sys 5 BASE_DIR=os.path.dirname(os.path.dirname(os.path.abspath(__file__)))#获取相对路径转为绝对路径赋于变量 6 sys.path.append(BASE_DIR)#增加环境变量 7 8 from core import students_main 9 from core.func_main import stud_alize10 11 if __name__ == '__main__':12 while True:13 print('''14 温馨提示:如果未注册可以自助注册15 1、自助注册16 2、进入登陆17 3、退出18 ''')19 s=input('请选择:')20 if s=='1':21 stud_alize()22 continue23 elif s=='2':24 students_main.stud_log()25 continue26 elif s=='3':27 exit()28 else:29 print('输入有误,请重输!')View Code

teacher.py

1 #!usr/bin/env python 2 #-*-coding:utf-8-*- 3 # Author calmyan 4 import os ,sys 5 BASE_DIR=os.path.dirname(os.path.dirname(os.path.abspath(__file__)))#获取相对路径转为绝对路径赋于变量 6 sys.path.append(BASE_DIR)#增加环境变量 7 8 from core.teacher_main import teach_log 9 10 if __name__ == '__main__':11 teach_log()View Code

config.py

1 #!usr/bin/env python 2 #-*-coding:utf-8-*- 3 # Author calmyan 4 import os ,sys 5 BASE_DIR=os.path.dirname(os.path.dirname(os.path.abspath(__file__)))#获取相对路径转为绝对路径赋于变量 6 sys.path.append(BASE_DIR)#增加环境变量 7 8 ADMIN_USER_FILE=BASE_DIR+'\db\\admin_user_list'#定义管理员列表文件变量 9 10 ADMIN_DIR=BASE_DIR+'\db\\admin_file\\'#定义管理员路径变量11 CLASS_DIR=BASE_DIR+'\db\\classes\\'#定义班级文件路径变量12 COURSE_DIR=BASE_DIR+'\db\\course\\'#定义学校课程文件路径变量13 STUD_DIR=BASE_DIR+'\db\\students_file\\'#定义学员文件路径变量14 TEACH_DIR=BASE_DIR+'\db\\teacher_file\\'#定义讲师文件路径变量15 SCHOOL_DIR=BASE_DIR+'\db\\schools\\'#定义学校路径变量16 TEAC_COUR_DIR=BASE_DIR+'\db\\teac_to_cour\\'#定义学校课程文件路径变量17 18 AMOUNT=300#每堂课收入基数19 20 21 USER_LOG=BASE_DIR+'\log\\user_log.log'#用户登陆日志文件22 USER_ERRO=BASE_DIR+'\log\\user_erro.log'#用户错误日志文件23 USER_OPERT=BASE_DIR+'\log\\user_operation.log'#用户操作日志文件24 25 ADMIN_LOG=BASE_DIR+'\log\\admin_log.log'#管理员登陆日志文件26 ADMIN_ERRO=BASE_DIR+'\log\\admin_erro.log'#管理员错误日志文件27 ADMIN_OPERT=BASE_DIR+'\log\\admin_operation.log'#管理员操作日志文件View Code

admin_main.py

1 #!usr/bin/env python 2 #-*-coding:utf-8-*- 3 # Author calmyan 4 import pickle 5 import os ,sys 6 BASE_DIR=os.path.dirname(os.path.dirname(os.path.abspath(__file__)))#获取相对路径转为绝对路径赋于变量 7 sys.path.append(BASE_DIR)#增加环境变量 8 #from core import user_pass 9 from core import class_main 10 from core import func_main 11 from core import log_file 12 from cfg import config 13 14 15 def loging():#运行函数 16 if func_main.file_char(config.ADMIN_USER_FILE):#检测相关文件是否不存在,进行初始化 17 print('系统还未进行初始化!') 18 func_main.initialize_admin()#进行初始化 19 while True: 20 print('管理员界面'.center(60,'=')) 21 print('按q/Q退出<<<

class_main.py

1 #!usr/bin/env python 2 #-*-coding:utf-8-*- 3 # Author calmyan 4 import os ,sys,pickle,uuid,time 5 BASE_DIR=os.path.dirname(os.path.dirname(os.path.abspath(__file__)))#获取相对路径转为绝对路径赋于变量 6 sys.path.append(BASE_DIR)#增加环境变量 7 8 9 from cfg import config 10 11 from core import id_classes 12 13 #基础类 14 class BasisClass(object):#基础类 15 def save(self): 16 file_dir=os.path.join(self.file_path,str(self.ID))#拼接文件路径 17 pickle.dump(self,open(file_dir,'wb'))#序列化到文件 18 19 @classmethod 20 def open_file_list(cls):#传入当前类 21 list_l=[]#定义一个列表 22 for file in os.listdir(cls.file_path):#循环输出对应目录下的文件 23 file_dir=os.path.join(cls.file_path,file)##拼接文件路径 24 list_l.append(pickle.load(open(file_dir,'rb')))#反序列化,追加到列表 25 return list_l#返回列表 26 27 #管理员类 28 class Admin(BasisClass): 29 file_path=config.ADMIN_DIR#管理员路经变量 30 def __init__(self,user,pwd): 31 self.ID=id_classes.Admin_id(self.file_path)#自动生成唯一ID 32 self.USER=user 33 self.PWD=pwd 34 self.create_time=time.strftime('%Y-%m-%d %H:%M:%S')#创建的时间 35 @staticmethod 36 def login(name,pas): 37 try: 38 for obj in Admin.open_file_list(): 39 if obj.USER == name and obj.PWD == pas: 40 tag=True 41 error='' 42 data='\033[32;1m登录成功\033[0m' 43 break 44 else: 45 raise Exception('\033[41;1m用户名或密码错误\033[0m' %name) 46 except Exception as e: 47 tag=False 48 error=str(e) 49 data='' 50 return {'tag':tag,'error':error,'data':data} 51 52 53 #学校类 54 class SchoolName(BasisClass): 55 file_path=config.SCHOOL_DIR#学校路径变量 56 def __init__(self,schoo_name,addr):#学校名称 地址 57 self.NAME=schoo_name#学校的名字 58 self.ADDR=addr#地址 59 self.ID=id_classes.Schools_id(self.file_path)#自动生成唯一ID 60 self.create_time=time.strftime('%Y-%m-%d %H:%M:%S')#创建的时间 61 self.amount=0#收入 62 # def get_amount(self): 63 # return str(self.__amount)#返回收入 64 def __str__(self): 65 return self.NAME 66 67 #班级类 68 class Class_leven(BasisClass):#续承学校类 69 '''班级类''' 70 file_path=config.CLASS_DIR#班级所在目录 71 number=0#班级数 72 def __init__(self,school_id,name,teac_to_cour_id):#学校, 班级名,讲师与课程 73 self.NAME=name 74 self.ID=id_classes.Class_id(self.file_path)#自动生成唯一ID 75 self.SCHOOL_ID=school_id#学校名字ID 76 self.create_time=time.strftime('%Y-%m-%d %H:%M:%S')#创建的时间 77 self.TEAC_TO_LSIT_ID=teac_to_cour_id#讲师与课程列表 78 Class_leven.number+=1 79 def __str__(self): 80 return self.NAME 81 82 83 84 # '''老师类''' 85 class Teacher(BasisClass): 86 number=0#老师人数 87 file_path=config.TEACH_DIR#讲师路经变量 88 def __init__(self,name,pwd,age,sex,leve,school_id):#名字,密码,年龄,性别,学校名 89 self.ID=id_classes.Teacher_id(self.file_path) 90 self.NAME=name 91 self.PWD=pwd 92 self.AGE=age 93 self.SEX=sex 94 self.LEVE=leve 95 self.SCHOOL_ID=school_id#关联学校 96 self.amount=0#收入 97 self.create_time=time.strftime('%Y-%m-%d %H:%M:%S')#创建的时间 98 Teacher.number+=1#创建时加1 99 def __str__(self):100 return self.NAME101 @staticmethod102 def login(name,pas):103 try:104 for obj in Teacher.open_file_list():105 if obj.NAME == name and obj.PWD == pas:106 tag=True107 error=''108 file_dir=os.path.join(obj.file_path,str(obj.ID))#拼接文件路径109 data=file_dir#返回对应的文件110 break111 else:112 raise Exception('\033[41;1m用户名或密码错误\033[0m' %name)113 except Exception as e:114 tag=False115 error=str(e)116 data=''117 return {'tag':tag,'error':error,'data':data}118 119 #'''学生类'''120 class Students(BasisClass):121 '''学生类'''122 file_path=config.STUD_DIR#学生文件路径变量123 number=0#学生总人数124 def __init__(self,num,name,pwd,age,sex,school_id,class_leven_id,phone):#学号,名字,年龄,性别,学校,班级,电话,分数,学费125 self.ID=id_classes.Students_id(self.file_path)126 self.NUM=num127 self.NAME=name128 self.PWD=pwd129 self.AGE=age130 self.SEX=sex131 self.SCHOOL_ID=school_id132 self.CLASS_ID=class_leven_id133 self.PHONE=phone134 self.SCORE=Score(self.NUM)135 self.create_time=time.strftime('%Y-%m-%d %H:%M:%S')#创建的时间136 self.FEES=0137 def __str__(self):138 return self.NAME139 @staticmethod140 def login(name,pas):#登陆检测141 try:142 for obj in Students.open_file_list():143 if obj.NAME == name and obj.PWD == pas:144 tag=True145 error=''146 file_dir=os.path.join(obj.file_path,str(obj.ID))#拼接文件路径147 data=file_dir#返回对应的文件148 break149 else:150 raise Exception('\033[41;1m用户名或密码错误\033[0m' %name)151 except Exception as e:152 tag=False153 error=str(e)154 data=''155 return {'tag':tag,'error':error,'data':data}156 157 158 159 #'''课程类'''160 class Course(BasisClass):161 file_path=config.COURSE_DIR#课程文件路径变量162 def __init__(self,name,cycle,fees,school_id,):#传入名字,周期,学费,学校对应的ID163 self.ID=id_classes.Course_id(self.file_path)#自动生成唯一ID164 self.NAME=name165 self.CYCLE=cycle166 self.FEES=fees167 self.SCHOOL_ID=school_id168 self.SCORE=Score(self.ID)#传入自身ID 实例化出来一个分数对象169 self.CREATE_TIME=time.strftime('%Y-%m-%d %H:%M:%S')#创建的时间170 def __str__(self):171 return self.NAME172 173 #讲师到课程174 class Teac_to_cour(BasisClass):175 '''讲师到课程'''176 file_path=config.TEAC_COUR_DIR#讲师到课程文件路径变量177 def __init__(self,course_name,teacher_name,school_id):#课程,讲师178 self.ID=id_classes.Teac_to_cour_id(self.file_path)#自动生成唯一ID179 self.NAME=teacher_name+'->'+course_name180 self.COURSE_NAME=course_name#课程名称181 self.TEACHER_NAME=teacher_name#讲师姓名182 self.SCHOOL_ID=school_id#学校ID183 def __str__(self):184 return self.NAME185 186 187 #分数类188 class Score():189 def __init__(self,nid):190 self.ID=nid#学号191 self.score_dict={}#分数字典192 193 def set(self,Teac_to_cour_id,number):194 self.score_dict[Teac_to_cour_id]=number#课程与讲师合到分数195 196 def get(self,Teac_to_cour_id):197 return self.score_dict[Teac_to_cour_id]#取出分数View Code

func_main.py

1 #!usr/bin/env python 2 #-*-coding:utf-8-*- 3 # Author calmyan 4 import os ,sys,pickle,uuid,hashlib,time 5 6 BASE_DIR=os.path.dirname(os.path.dirname(os.path.abspath(__file__)))#获取相对路径转为绝对路径赋于变量 7 sys.path.append(BASE_DIR)#增加环境变量 8 from cfg import config 9 from core import class_main 10 from core import log_file 11 12 13 #id生成 14 def id_uu(): 15 return str(uuid.uuid1()) 16 #id生成 17 def id_md5(): 18 id_i=hashlib.md5() 19 id_i.update(bytes(str(time.time()),encoding='utf8')) 20 return id_i.hexdigest()#返回用时间创建 的ID 21 22 #初始化检测 23 def file_char(name):# 24 if not os.path.exists(name):#检测相关文件是否不存在 25 #info={'北京':[],'上海':[]} 26 #file_pick(name,info)#进行初始化 27 return True 28 else: 29 return False 30 31 #初始化管理员 32 def initialize_admin(): 33 print('系统正在初始化....') 34 try: 35 user = input('请输入初始化用户名:') 36 pwd = input('请输入初始化密码:') 37 obj = class_main.Admin(user, pwd) 38 obj.save() 39 with open(config.ADMIN_USER_FILE,'w') as f: 40 f.write('yes')#应文件用来确认初始化 41 return True 42 except Exception as e: 43 print(e) 44 45 #创建学校函数 46 def car_school(): 47 try: 48 print('提示: B/b 返回上级!') 49 names=input('请输入您要添加的学校名字:').strip() 50 if names=='b' or names=='B': 51 return 52 addrs=input('请输入学校所在地址:').strip() 53 if addrs=='b' or addrs=='B': 54 return 55 school_name_list=[(obj.NAME,obj.ADDR) for obj in class_main.SchoolName.open_file_list()]#进行学校校区重名检测用,返回列表 56 if (names,addrs) in school_name_list: 57 print('\033[41;1m[%s] [%s]校区 已经存在,不可重复创建\033[0m' %(names,addrs)) 58 return 59 else: 60 obj=class_main.SchoolName(names,addrs)#创建学校 61 obj.save()#pickle序列化保存到文件 62 print('\033[32;1m创建[%s] 学校,[%s]校区成功!\033[0m'%(names,addrs)) 63 return 64 except Exception as e: 65 print(e) 66 67 #查看学校 68 def show_school(): 69 for obj in class_main.SchoolName.open_file_list(): 70 #amo=obj.get_amount() 71 print('\033[32;1m学校[%s] 地址[%s] 总收入[%s] 创建日期[%s] \033[0m'.center(60,'-') %(obj.NAME,obj.ADDR,obj.amount,obj.create_time)) 72 73 #创建课程函数 74 def car_course(): 75 print('\033[36;1m创建课程\033[0m'.center(60,'=')) 76 school_list=class_main.SchoolName.open_file_list()#打开学校列表 77 try: 78 #while True: 79 print('\033[33;1m提示: B/b 返回上级!\033[0m') 80 fon=input('===============其他键确认开始创建课程:') 81 if fon=='b' or fon=='B': 82 return 83 for k,obj in enumerate(school_list): 84 print('\033[35;1m学校编号:%s,学校名称:%s,校区:%s\033[0m'%(k,obj,obj.ADDR)) 85 sch_name=int(input('请选择学校: ')) 86 school_obj=school_list[sch_name]#用数字选定学校 87 # print(school_list[sch_name]) 88 # print(school_obj.ID.ID) 89 course_name=input('请输入要创建的课程名:').strip() 90 price=input('请输入课程价格: ').strip() 91 period=input('请输入课程周期: ').strip() 92 course_name_list=[(obj.NAME,obj.SCHOOL_ID.ID) for obj in class_main.Course.open_file_list()]#返回所有课程是名字,对应的学校列表 93 if (course_name,school_obj.ID.ID) in course_name_list:#查课程名,与学校名是否存 94 print('\033[43;1m课程[%s] 已经存在,不能重复创建\033[0m' %(course_name)) 95 return 96 else: 97 obj=class_main.Course(course_name,period,price,school_obj.ID) 98 obj.save() 99 print('\033[33;1m课程[%s] 价格[%s] 周期[%s]创建成功\033[0m' %(obj.NAME,obj.FEES,obj.CYCLE))100 return101 except Exception as e:102 return print('选择有误,请重新选择')103 104 #查看课程105 def show_course():106 for obj in class_main.Course.open_file_list():#调用ID类中的方法107 print('\033[32;1m[%s] [%s]校区 [%s]课程 价格[%s] 周期[%s]\033[0m'.center(60,'-')%(obj.SCHOOL_ID.get_id_file().NAME,obj.SCHOOL_ID.get_id_file().ADDR,obj.NAME,obj.FEES,obj.CYCLE))108 109 #创建讲师函数110 def car_teacher():111 print('\033[36;1m创建讲师\33[0m'.center(60,'='))112 school_list=class_main.SchoolName.open_file_list()#打开学校列表113 try:114 #while True:115 print('\033[33;1m提示: B/b 返回上级!\033[0m')116 fon=input('===============其他键确认开始创建讲师:')117 if fon=='b' or fon=='B':118 return119 for k,obj in enumerate(school_list):120 print('\033[35;1m学校编号:%s,学校名称:%s,校区:%s\033[0m'%(k,obj,obj.ADDR))121 sch_name=int(input('请选择学校: '))122 school_obj=school_list[sch_name]#用数字选定学校123 uname=input('请输入要创建的讲师名字:').strip()124 upwd=input('请输入讲师登陆密码:').strip()125 uleve=input('请输入讲师级别:').strip()126 uage=input('请输入年龄:').strip()127 usex=input('请输入性别:').strip()128 uname_list=[(obj.NAME,obj.SCHOOL_ID.ID) for obj in class_main.Teacher.open_file_list()]#返回所有讲师是名字,对应的学校列表129 if (uname,school_obj.ID.ID) in uname_list:#查讲师名,与学校名是否存130 print('\033[43;1m讲师[%s] 已经存在,不能重复创建\033[0m' %(uname))131 return132 else:133 obj=class_main.Teacher(uname,upwd,uage,usex,uleve,school_obj.ID)134 obj.save()135 print('\033[33;1m[%s] [%s]校区 讲师[%s] 创建成功\033[0m' %(obj.SCHOOL_ID.get_id_file().NAME,obj.SCHOOL_ID.get_id_file().ADDR,obj.NAME))136 return137 except Exception as e:138 return print('选择有误,请重新选择')139 140 #查看讲师141 def show_teacher():142 for obj in class_main.Teacher.open_file_list():#调用ID类中的方法143 print('\033[32;1m[%s] [%s]校区 [%s]讲师 性别:[%s] 级别[%s] 创建时间[%s]\033[0m'.center(60,'-')%(obj.SCHOOL_ID.get_id_file().NAME,obj.SCHOOL_ID.get_id_file().ADDR,obj.NAME,obj.SEX,obj.LEVE,obj.create_time))144 145 #创建班级函数146 def car_classes():147 print('\033[36;1m创建班级\33[0m'.center(60,'='))148 school_list=class_main.SchoolName.open_file_list()#打开学校列表149 try:150 #while True:151 print('\033[33;1m提示: B/b 返回上级!\033[0m')152 fon=input('===============其他键确认开始创建班级:')153 if fon=='b' or fon=='B':154 return155 for k,obj in enumerate(school_list):156 print('\033[35;1m学校编号:%s,学校名称:%s,校区:%s\033[0m'%(k,obj,obj.ADDR))157 sch_name=int(input('请选择学校: '))158 school_obj=school_list[sch_name]#用数字选定学校159 uname=input('请输入要创建的班级名:').strip()160 uname_list=[(obj.NAME,obj.SCHOOL_ID.ID) for obj in class_main.Class_leven.open_file_list()]#返回所有班级是名字,对应的学校列表161 if (uname,school_obj.ID.ID) in uname_list:#查课程名,与学校名是否存162 print('\033[43;1m[%s] [%s]校区 ,[%s]班级 已经存在,不能重复创建\033[0m' %(school_obj.ID.get_id_file().NAME,school_obj.ID.get_id_file().ADDR,uname))163 return164 else:165 teac_to_cour_list=class_main.Teac_to_cour.open_file_list()#打关联列表166 for k ,obj in enumerate(teac_to_cour_list):167 if str(school_obj.ID)==str(obj.SCHOOL_ID.ID):168 print('\033[35;1m课程编号:%s,关联的讲师:%s\033[0m'%(k,obj))169 coures_name=int(input('请选择讲师与课程'))170 teac_to_cour_obj=teac_to_cour_list[coures_name]171 obj=class_main.Class_leven(school_obj.ID,uname,teac_to_cour_obj.ID)172 obj.save()173 print('\033[33;1m[%s] [%s]校区 [%s]班级 创建成功\033[0m' %(obj.SCHOOL_ID.get_id_file().NAME,obj.SCHOOL_ID.get_id_file().ADDR,obj.NAME))174 return175 except Exception as e:176 return print('选择有误,请重新选择')177 178 #查看班级179 def show_classes():180 for obj in class_main.Class_leven.open_file_list():#调用ID类中的方法 学校ID 老师到课程ID181 print('\033[32;1m[%s] [%s]校区 [%s]班 所开课程:[%s] 讲师:[%s]\033[0m'.center(60,'-')%(obj.SCHOOL_ID.get_id_file().NAME,\182 obj.SCHOOL_ID.get_id_file().ADDR,\183 obj.NAME,\184 obj.TEAC_TO_LSIT_ID.get_id_file().COURSE_NAME,obj.TEAC_TO_LSIT_ID.get_id_file().TEACHER_NAME))185 186 #关联课程187 def associated_course():188 try:189 #while True:190 school_list=class_main.SchoolName.open_file_list()#打开学校列表191 print('课程关联'.center(60,'='))192 for k,obj in enumerate(school_list):193 print('\033[35;1m学校编号:%s,学校名称:%s,校区:%s\033[0m'%(k,obj,obj.ADDR))194 sch_name=int(input('请选择学校: '))195 school_obj=school_list[sch_name]#用数字选定学校196 course_list=class_main.Course.open_file_list()#打开课程列表197 for k,obj in enumerate(course_list):198 if str(obj.SCHOOL_ID.ID)==str(school_obj.ID):#判断学校名是否相同199 print('\033[35;1m课程编号:%s,课程名称:%s\033[0m'%(k,obj))200 cou_name=int(input('请选择课程: '))201 course_obj=course_list[cou_name]#用数字选定课程202 teacher_list=class_main.Teacher.open_file_list()#打开讲师列表203 for k,obj in enumerate(teacher_list):204 if str(obj.SCHOOL_ID.ID)==str(school_obj.ID):#判断学校名是否相同205 print('\033[35;1m讲师编号:%s,讲师姓名:%s\033[0m'%(k,obj))206 teach_name=int(input('请选择讲师: '))207 teach_obj=teacher_list[teach_name]#用数字选定老师208 uname_list=[(obj.COURSE_NAME,obj.TEACHER_NAME,obj.SCHOOL_ID.ID) for obj in class_main.Teac_to_cour.open_file_list()]#返回所有关联课程列表209 if (course_obj.NAME,teach_obj.NAME,school_obj.ID.ID) in uname_list:#查课程名,与学校名是否存210 print('\033[43;1m[%s] [%s]校区 ,课程[%s]与[%s] 已经关联,不能重复关联\033[0m' %(school_obj.ID.get_id_file().NAME,school_obj.ID.get_id_file().ADDR,course_obj.NAME,teach_obj.NAME))211 return212 else:213 obj=class_main.Teac_to_cour(course_obj.NAME,teach_obj.NAME,school_obj.ID)214 obj.save()215 print('\033[33;1m[%s] [%s]校区 ,课程[%s]与[%s] 关联成功\033[0m' %(obj.SCHOOL_ID.get_id_file().NAME,obj.SCHOOL_ID.get_id_file().ADDR,obj.COURSE_NAME,obj.TEACHER_NAME))216 return217 except Exception as e:218 return print('选择有误,请重新选择')219 220 #查看课程关联221 def show_teac_to_cour():222 for obj in class_main.Teac_to_cour.open_file_list():223 print('\033[32;1m[%s] [%s]校区 课程:[%s] 讲师:[%s]\033[0m'.center(60,'=')%(obj.SCHOOL_ID.get_id_file().NAME,\224 obj.SCHOOL_ID.get_id_file().ADDR,\225 obj.COURSE_NAME,obj.TEACHER_NAME))226 227 #学员自动注册228 def stud_alize():229 print('\033[36;1m学员自助注册\33[0m'.center(60,'='))230 school_list=class_main.SchoolName.open_file_list()#打开学校列表231 try:232 #while True:233 print('\033[33;1m提示: B/b 返回上级!\033[0m')234 fon=input('===============其他键确认开始注册:')235 if fon=='b' or fon=='B':236 return237 for k,obj in enumerate(school_list):238 print('\033[35;1m学校编号:%s,学校名称:%s,校区:%s\033[0m'%(k,obj,obj.ADDR))239 sch_name=int(input('请选择您要注册的学校: '))240 uname_list=[(obj.NUM,obj.PHONE) for obj in class_main.Students.open_file_list()]#返回所有学员的名字,对应的学校,电话号码列表241 school_obj=school_list[sch_name]#用数字选定学校242 unum=int(input('请输入您要的学号:').strip())243 if (unum)in uname_list:#查学号是否存244 print('\033[43;1m学号[%s] 已经存在,不能重复创建\033[0m' %(unum))245 return246 uname=input('请输入注册名字:').strip()247 upwd=input('请输入登陆密码:').strip()248 uphone=input('请输入电话号码:').strip()249 uage=input('请输入年龄:').strip()250 usex=input('请输入性别:').strip()251 if (uphone) in uname_list:#查电话是否存252 print('\033[43;1m学员[%s] 电话号码已经存在,不能重复创建\033[0m' %(uname))253 return254 else:255 class_list=class_main.Class_leven.open_file_list()#打开班级256 for k,obj in enumerate(class_list):257 if str(obj.SCHOOL_ID.ID)==str(school_obj.ID):#判断学校名是否相同258 print('\033[35;1m班级编号:%s, [%s]\033[0m'%(k,obj))259 uclass_name=int(input('请选择班级:'))260 class_name_obj=class_list[uclass_name]#261 obj=class_main.Students(unum,uname,upwd,uage,usex,school_obj.ID,class_name_obj.ID,uphone)262 obj.save()263 print('\033[33;1m[%s] [%s]校区 学员[%s] 注册成功\033[0m' %(obj.SCHOOL_ID.get_id_file().NAME,obj.SCHOOL_ID.get_id_file().ADDR,obj.NAME))264 return265 except Exception as e:266 return print('输入有误,请重新选择')267 268 269 #创建学员270 def car_students():271 print('\033[36;1m创建学员\33[0m'.center(60,'='))272 school_list=class_main.SchoolName.open_file_list()#打开学校列表273 try:274 #while True:275 print('\033[33;1m提示: B/b 返回上级!\033[0m')276 fon=input('===============其他键确认开始创建学员:')277 if fon=='b' or fon=='B':278 return279 for k,obj in enumerate(school_list):280 print('\033[35;1m学校编号:%s,学校名称:%s,校区:%s\033[0m'%(k,obj,obj.ADDR))281 sch_name=int(input('请选择学校: '))282 uname_list=[(obj.NUM,obj.PHONE) for obj in class_main.Students.open_file_list()]#返回所有学员的名字,对应的学校,电话号码列表283 school_obj=school_list[sch_name]#用数字选定学校284 unum=int(input('请输入要创建学员学号:').strip())285 if (unum)in uname_list:#查学号是否存286 print('\033[43;1m学号[%s] 已经存在,不能重复创建\033[0m' %(unum))287 return288 uname=input('请输入要创建学员名字:').strip()289 upwd=input('请输入学员登陆密码:').strip()290 uphone=input('请输入电话号码:').strip()291 uage=input('请输入年龄:').strip()292 usex=input('请输入性别:').strip()293 if (uphone) in uname_list:#查电话是否存294 print('\033[43;1m学员[%s] 电话号码已经存在,不能重复创建\033[0m' %(uname))295 return296 else:297 class_list=class_main.Class_leven.open_file_list()#打开班级298 for k,obj in enumerate(class_list):299 if str(obj.SCHOOL_ID.ID)==str(school_obj.ID):#判断学校名是否相同300 print('\033[35;1m班级编号:%s, [%s]\033[0m'%(k,obj))301 uclass_name=int(input('请选择班级:'))302 class_name_obj=class_list[uclass_name]#303 obj=class_main.Students(unum,uname,upwd,uage,usex,school_obj.ID,class_name_obj.ID,uphone)304 obj.save()305 print('\033[33;1m[%s] [%s]校区 学员[%s] 创建成功\033[0m' %(obj.SCHOOL_ID.get_id_file().NAME,obj.SCHOOL_ID.get_id_file().ADDR,obj.NAME))306 return307 except Exception as e:308 return print('输入有误,请重新选择')309 310 #查看学员311 def show_students():312 for obj in class_main.Students.open_file_list():313 print('\033[32;1m[%s] [%s]校区 学员编号:[%s] 学员姓名:[%s] 年龄:[%s] 性别:[%s] 电话:[%s] 所在班级:[%s]\033[0m'.center(60,'=')%(obj.SCHOOL_ID.get_id_file().NAME,\314 obj.SCHOOL_ID.get_id_file().ADDR,obj.NUM,\315 obj.NAME,obj.AGE,obj.SEX,obj.PHONE,obj.CLASS_ID.get_id_file().NAME))316 317 318 319 #学员个人信息查看320 321 def show_info(obj):322 info='''\033[34;1m323 学号:{NUM}\t\t\t姓名:{NAME}\t\t\t年龄:{AGE}\t\t\t性别:{SEX}\t\t\t电话:{PHONE}324 325 学校:{SCHOOL}\t\t\t校区:{SCHOOL_}\t\t\t班级:{CLASS}\t\t\t学费:{FEES}\t\t\t分数:{SCORE}326 327 \033[0m'''.format(NUM=str(obj.NUM),NAME=obj.NAME,AGE=obj.AGE,SEX=obj.SEX,PHONE=obj.PHONE,\328 SCHOOL=obj.SCHOOL_ID.get_id_file().NAME,SCHOOL_=obj.SCHOOL_ID.get_id_file().ADDR,\329 CLASS=obj.CLASS_ID.get_id_file().NAME,FEES=str(obj.FEES),SCORE=obj.SCORE.score_dict)330 331 print(info)332 333 #讲师个人信息查看334 335 def show_teach_info(obj):336 info='''\033[34;1m337 姓名:{NAME}\t\t\t年龄:{AGE}\t\t\t性别:{SEX}\t\t\t338 339 学校:{SCHOOL}\t\t\t校区:{SCHOOL_}\t\t\t级别:{LEVE}\t\t\t收入:{amount}340 341 \033[0m'''.format(NAME=obj.NAME,AGE=obj.AGE,SEX=obj.SEX,\342 SCHOOL=obj.SCHOOL_ID.get_id_file().NAME,SCHOOL_=obj.SCHOOL_ID.get_id_file().ADDR,\343 LEVE=obj.LEVE,amount=str(obj.amount))344 345 print(info)346 347 #讲师操作相关函数348 def teacher_char_l(obj_teach):349 class_teach_list=[]#讲师的班级列表350 for obj in class_main.Class_leven.open_file_list():#打开班级列表351 if obj_teach.NAME==obj.TEAC_TO_LSIT_ID.get_id_file().TEACHER_NAME:#查询对应的课程老师352 class_teach_list.append(obj)#加入列表353 return class_teach_list#讲师的班级列表354 355 #讲师操作相关函数查看学生356 def teacher_char_class(class_teach_list):357 while True:358 for k,obj in enumerate(class_teach_list):359 print('\033[32;1m班级编号:%s 班级名称:[%s]\033[0m'%(k,obj))360 try:361 sart_class=int(input('请选择您要查看的学员班级编号:'))362 sart_class_obj=class_teach_list[sart_class]#用数字选定班级363 for obj in class_main.Students.open_file_list():#查看学生364 if str(obj.CLASS_ID.get_id_file().NAME)==str(sart_class_obj.NAME):#查看对应班级365 print('\033[34;1m学号:[%s] 姓名:[%s]\033[0m'%(obj.NUM,obj.NAME))366 return367 except Exception as e:368 print('选择有误,请重新选择')369 else:370 print('\033[31;1m对不起,您还没有分配班级与课程,请与校方联系!\033[0m')371 372 373 #讲师操作相关函数学员成绩374 def teacher_char_class_students(class_teach_list):375 while True:376 for k,obj in enumerate(class_teach_list):377 print('\033[32;1m班级编号:%s 班级名称:[%s]\033[0m'%(k,obj))378 try:379 sart_class=int(input('请选择您要查看的学员班级编号:'))380 sart_class_obj=class_teach_list[sart_class]#用数字选定班级381 students_list=[]382 for obj in class_main.Students.open_file_list():#查看学习383 if str(obj.CLASS_ID.get_id_file().NAME)==str(sart_class_obj.NAME):#查看对应班级384 #print('\033[34;1m学号:[%s] 姓名:[%s]\033[0m'%(obj.NUM,obj.NAME))385 students_list.append(obj)#返回当前班级学员列表386 return students_list387 except Exception as e:388 print('选择有误,请重新选择')389 else:390 print('\033[31;1m对不起,您还没有分配班级与课程,请与校方联系!\033[0m')391 392 393 #获取学生上课课程函数394 def studnts_class(class_name):395 for obj in class_main.Course.open_file_list():#返回所有课程的名字396 if class_name==str(obj.NAME):397 return obj398 399 400 #交学费401 def jxf(file_dir,user):402 obj=pickle.load(open(file_dir,'rb'))403 money=input('请输入学费金额:')404 if money.isdigit():#是否为整数405 obj.FEES=obj.FEES+int(money)406 obj.save()#进行保存407 print("交费成功,金额:\033[32;1m%s\033[0m"%money)408 file_dir=os.path.join(config.SCHOOL_DIR,str(obj.SCHOOL_ID.get_id_file().ID))##拼接文件路径409 school_obj=pickle.load(open(file_dir,'rb'))#反序列化,追加到文件410 school_obj.amount+=int(money)411 school_obj.save()#进行保存412 info_str='%s 学员进行交费,金额:[%s]'%(user,money)413 log_file.user_opert(info_str)414 else:415 print('请正确输入整数!')View Codeid_classes.py

1 #!usr/bin/env python 2 #-*-coding:utf-8-*- 3 # Author calmyan 4 import pickle,os 5 from core import func_main 6 # ID 类 7 class id_mode(object):#id 基础类 8 def __init__(self,file_path): 9 self.ID=func_main.id_uu()##自动生成唯一ID10 self.File_path=file_path#传入的路径11 def __str__(self):12 return self.ID13 def get_id_file(self):#通过ID找到对应文件14 for filename in os.listdir(self.File_path):15 if filename == self.ID:16 file_dir=os.path.join(self.File_path,self.ID)#拼接文件路径17 return pickle.load(open(file_dir,'br'))#返回反序列化的文件对象18 return None19 20 class Admin_id(id_mode):#管理员类21 def __init__(self,file_path):22 super(Admin_id,self).__init__(file_path) #23 24 class Class_id(id_mode):#班级类25 def __init__(self,file_path):26 super(Class_id,self).__init__(file_path)27 28 class Course_id(id_mode):#课程类\29 def __init__(self,file_path):30 super(Course_id,self).__init__(file_path)31 32 class Schools_id(id_mode):#学校类33 def __init__(self,file_path):34 super(Schools_id,self).__init__(file_path)35 36 class Students_id(id_mode):#学生类37 def __init__(self,file_path):38 super(Students_id,self).__init__(file_path)39 40 class Teac_to_cour_id(id_mode):#讲师到课程类41 def __init__(self,file_path):42 super(Teac_to_cour_id,self).__init__(file_path)43 44 class Teacher_id(id_mode):#讲师类45 def __init__(self,file_path):46 super(Teacher_id,self).__init__(file_path)View Code

log_file.py

1 #!usr/bin/env python 2 #-*-coding:utf-8-*- 3 # Author calmyan 4 #日志记录相关函数 5 import os,logging,time 6 from cfg import config 7 8 9 def log_err(info_str):#错误日志,传入的错误内容10 logger=logging.getLogger('用户登陆错误日志')#设置日志模块11 logger.setLevel(logging.DEBUG)12 fh=logging.FileHandler(config.USER_ERRO,encoding='utf-8')#写入文件13 fh.setLevel(logging.DEBUG)#写入信息的级别14 fh_format=logging.Formatter('%(asctime)s %(message)s',datefmt='%m/%d/%Y %I:%M:%S %p')#日志格式15 fh.setFormatter(fh_format)#关联格式16 logger.addHandler(fh)#添加日志输出模式17 logger.warning(info_str)18 return 019 20 def log_log(info_str):#登陆日志,传入内容21 logger=logging.getLogger('用户成功登陆日志')#设置日志模块22 logger.setLevel(logging.DEBUG)23 fh=logging.FileHandler(config.USER_LOG,encoding='utf-8')#写入文件24 fh.setLevel(logging.DEBUG)#写入信息的级别25 fh_format=logging.Formatter('%(asctime)s %(message)s',datefmt='%m/%d/%Y %I:%M:%S %p')#日志格式26 fh.setFormatter(fh_format)#关联格式27 logger.addHandler(fh)#添加日志输出模式28 logger.warning(info_str)29 return 030 31 def user_opert(info_str):#用户操作日志,传入内容32 logger=logging.getLogger('用户操作日志')#设置日志模块33 logger.setLevel(logging.CRITICAL)34 fh=logging.FileHandler(config.USER_OPERT,encoding='utf-8')#写入文件35 fh.setLevel(logging.CRITICAL)#写入信息的级别36 fh_format=logging.Formatter('%(asctime)s %(message)s',datefmt='%m/%d/%Y %I:%M:%S %p')#日志格式37 fh.setFormatter(fh_format)#关联格式38 logger.addHandler(fh)#添加日志输出模式39 logger.critical(info_str)40 return 041 42 43 44 def admin_log(info_str):#管理员登陆日志,传入内容45 logger=logging.getLogger('管理员成功登陆日志')#设置日志模块46 logger.setLevel(logging.DEBUG)47 fh=logging.FileHandler(config.ADMIN_LOG,encoding='utf-8')#写入文件48 fh.setLevel(logging.DEBUG)#写入信息的级别49 fh_format=logging.Formatter('%(asctime)s %(message)s',datefmt='%m/%d/%Y %I:%M:%S %p')#日志格式50 fh.setFormatter(fh_format)#关联格式51 logger.addHandler(fh)#添加日志输出模式52 logger.warning(info_str)53 return 054 55 def admin_err(info_str):#管理员错误日志,传入的错误内容56 logger=logging.getLogger('管理员登陆错误日志')#设置日志模块57 logger.setLevel(logging.DEBUG)58 fh=logging.FileHandler(config.ADMIN_ERRO,encoding='utf-8')#写入文件59 fh.setLevel(logging.DEBUG)#写入信息的级别60 fh_format=logging.Formatter('%(asctime)s %(message)s',datefmt='%m/%d/%Y %I:%M:%S %p')#日志格式61 fh.setFormatter(fh_format)#关联格式62 logger.addHandler(fh)#添加日志输出模式63 logger.warning(info_str)64 return 065 66 def admin_opert(info_str):#管理员操作日志,传入内容67 logger=logging.getLogger('管理员操作日志')#设置日志模块68 logger.setLevel(logging.CRITICAL)69 fh=logging.FileHandler(config.ADMIN_OPERT,encoding='utf-8')#写入文件70 fh.setLevel(logging.CRITICAL)#写入信息的级别71 fh_format=logging.Formatter('%(asctime)s %(message)s',datefmt='%m/%d/%Y %I:%M:%S %p')#日志格式72 fh.setFormatter(fh_format)#关联格式73 logger.addHandler(fh)#添加日志输出模式74 logger.critical(info_str)75 return 0View Code

students_main.py

1 #!usr/bin/env python 2 #-*-coding:utf-8-*- 3 # Author calmyan 4 import os ,sys,pickle,time 5 BASE_DIR=os.path.dirname(os.path.dirname(os.path.abspath(__file__)))#获取相对路径转为绝对路径赋于变量 6 sys.path.append(BASE_DIR)#增加环境变量 7 from cfg import config 8 from core.class_main import Students 9 from core.class_main import Course10 11 from core.func_main import show_info12 from core.func_main import studnts_class13 from core.func_main import jxf14 from core import log_file15 16 17 18 def stud_log():#学生登陆19 while True:20 print('学生登陆界面'.center(60,'='))21 print('按q/Q退出<<<=int(class_obj.FEES):#如果交的学费大于课程的费用才能上课74 print('开始上课....')75 for i in range(50):#加载动画76 sys.stdout.write('#')77 sys.stdout.flush()78 time.sleep(0.05)79 print('\n恭喜!您已经完成本次课时.....')80 info_str='%s 学员上课,完成课时!'%(user)81 log_file.user_opert(info_str)82 continue83 else:84 print('您的学费不够,请先交学费')85 continue86 elif foo=='4':87 print('您已经成功退出!')88 info_str='学员[%s] 成功退出 '%user89 log_file.log_log(info_str)90 exit()91 else:92 print('选择有误,请重新选择!')93 continue94 else:95 print('用户名或密码错误请重输入')96 info_str='%s登陆错误!'%user97 log_file.log_err(info_str)98 continueView Code

teacher_main.py

1 #!usr/bin/env python 2 #-*-coding:utf-8-*- 3 # Author calmyan 4 #上课时选择班级, 查看班级学员列表 , 修改所管理的学员的成绩 5 import os ,sys,pickle,time 6 BASE_DIR=os.path.dirname(os.path.dirname(os.path.abspath(__file__)))#获取相对路径转为绝对路径赋于变量 7 sys.path.append(BASE_DIR)#增加环境变量 8 from core.class_main import Teacher 9 from core.func_main import teacher_char_l 10 from core.func_main import teacher_char_class 11 from core.func_main import teacher_char_class_students 12 from core.func_main import show_teach_info 13 from cfg import config 14 from core import log_file 15 def teach_log():#讲师运行函数 16 while True: 17 print('讲师界面'.center(60,'=')) 18 print('按q/Q退出<<<

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

本文系统来源:php中文网

python123注册需要输入真实姓名和学校吗_python-----作业完成--学校选课系统相关推荐

  1. python123注册需要输入真实姓名和学校吗_Python 校园选课系统

    面向对象作业--校园选课系统 角色: 学校.学员.课程.讲师 要求: 1. 创建北京.上海 2 所学校 2. 创建linux , python , go 3个课程 , linux\py 在北京开, g ...

  2. 如何通过API查询指定的手机号或邮箱查询是否注册支付宝以及真实姓名?

    相信很多朋友有这个需求 ,在这里推荐一个平台:帝京云.下面让我们康康如何使用吧: 打开帝京云进行注册 登录 点击财务充值[在此演示支付宝] 4.充值成功 5.回到首页点击新建应用 6.购买套餐 7.记 ...

  3. 学校机房网上作业发放、提交系统案例

    传统的对学生作业管理是在服务器上建立一个FTP服务器,然后对学生用户设置一个专门的帐号,只允许对作业进行上传/下载,然后学生将作业上传到服务器里面对应的班级文件夹下面.这种传统的方法可能导致学生之间相 ...

  4. python验证身份证号码大全_国服魔兽注册账号需要验证身份证及真实姓名

    网易<魔兽世界>注册中需要验证姓名和身份证号码,如果不吻合就无法通过验证. 同样的对象---网游企业,同样的内容---用户注册实名,不同的部委---文化部和新闻出版总署各自推行网游实名制. ...

  5. 正则-完美的身份证以及真实姓名

    验证真实姓名的正则(2-30位): var reg= /^(([a-zA-Z+\.?\·?a-zA-Z+]{2,30}$)|([\u4e00-\u9fa5+\·?\u4e00-\u9fa5+]{2,3 ...

  6. 才发现网易相册已于2019年5月8号停止运营,如何导出相册照片:http://photo.163.com/transfer/html/login , 使用相册帐号登录,提供真实姓名、手机号码

    网易相册已于2019年5月8号停止运营. 如果您想找回网易相册信息,麻烦您点击这里下载app之后登录邮箱, 在app中点击[我的]页面-[帮助与反馈]进入帮助中心, 点击[博客与相册]-[如何导出相册 ...

  7. Vue 正则表达式验证表单字段(如用户名/密码/真实姓名/身份证/手机号/邮箱)的合法性

    1. 给页面表单对象添加验证属性 由于我的项目使用的el-form,则给el-form添加属性  :rules="registerRules" ref="register ...

  8. js验证真实姓名与身份证号,手机号

    最近的项目中用的需要调用实名认证的接口,实名认证接口价格相比短信而言高了不是几分钱,所以说调用实名认证的条件就要严格把关,因此用到js验证真实姓名与js验证身份证号. 进入正题 1.js验证真实姓名 ...

  9. 编写一个用户类(Sysuser),属性包括用户名、真实姓名、年龄、出生日期、密码,类方法中包含单独修改用户年龄、判断用户名和密码、显示用户信息功能,在用户测试类中(TestSysuser),根据用户输

    #本关任务: 编写一个用户类(Sysuser),属性包括用户名.真实姓名.年龄.出生日期.密码,类方法中包含单独修改用户年龄.判断用户名和密码.显示用户信息功能,在用户测试类中(TestSysuser ...

最新文章

  1. HarmonyOS之分布式任务调度开发流程
  2. mac安全与隐私只有两个选项,少了一个任何来源
  3. spring roo_使用Spring Roo进行概念验证
  4. pytest+allure生成漂亮的报告+显示
  5. 学生开源项目_吸引学生加入您的开源项目的9种方法
  6. Python中的split()和rsplit()的使用
  7. idea Error:(1, 10) java: 需要class, interface或enum, 未结束的字符串文字,Error:(55, 136) java: 非法字符: \65533...
  8. openstack changePassword
  9. 判断进程是否正在运行
  10. 几何画板中该如何插入公式
  11. 用 Wolfram 语言绘制电子轨道
  12. 2004-2020历年美赛优秀论文资源
  13. 在c语言中整数除以0,整数除零在哪些平台上触发浮点异常?
  14. 用matlab做随机实验1
  15. 关于SpringMVC的XML配置步骤
  16. oracle千万级数据量的表关联更新
  17. html时间选择控件火狐浏览器,火狐浏览器Mozilla Firefox
  18. 百度快照被劫持百度网址安全中心提醒您:该页面可能已被非法篡改
  19. 近年来作品整理——软件和网站设计小结
  20. javascript学习_真正学习javascript

热门文章

  1. Python分析离散心率信号(中)
  2. CVPR2020最新论文扫描盘点(上)
  3. 2021年大数据Flink(三):​​​​​​​Flink安装部署 Local本地模式
  4. 【CV】深度学习中Epoch, Batch, Iteration的含义
  5. Android 10 新增的功能
  6. Manifest merger failed with multiple errors, see logs
  7. Dundas使用手册
  8. 【WinForm】“System.Data.SqlClient.SqlConnection”的类型初始值设定项引发异常
  9. 中国互联网+户外广告行业商业模式创新与投资机会深度研究报告
  10. CentOS7部署ELK5.2