python第三次作业

1.使用os和os.path以及函数的递归完成:

给出一个路径,遍历当前路径所有的文件及文件夹

打印输出所有的文件(遇到文件输出路径,遇到文件夹继续进文件夹)

python 复制代码
import os
from os import path
#创建递归函数
def scanner_file(url):
    files = os.listdir(url)
    for i in files:    
        real_path = path.join(url,i)#拼接当前项的路径
        if path.isfile(real_path):#判断是否为文件,若是则打印完整路径
            print(real_path)
        elif path.isdir(real_path):#判断是否为目录,若是则继续递归调用自身进行扫描
            scanner_file(real_path)
        else:
            print("其他情况")
            pass
scanner_file("E:\云计算")

运行结果

2.使用加密模块及IO模拟登录功能,要求使用文件模拟数据库存储用户名和密码。

python 复制代码
import hmac
database = {}
def encryption_admin(str):
    slat = "&^$$^$&&()*^#@!".encode("utf-8")
    return hmac.new(str.encode("utf-8"),slat,"md5").hexdigest()
#初始化数据库中的用户名和密码哈希值
database["username"] = encryption_admin("zhangsan")
database["password"] = encryption_admin("123456")
username,password = input("请输入用户名和密码并使用空格分隔:").split(" ")
#验证哈希值
if (encryption_admin(username) == database["username"] and encryption_admin(password) == database["password"]):
    print("login success")
else:
    print("login failure")

运行结果

3.使用面向对象编程完成学生信息录入功能,数据存储在本地文件txt中,并读取学生信息并按照成绩进行排序,学生其他属性自行规划

python 复制代码
import time
students = []
def main():
    while True:
        i = int(input("是否继续录入(1为继续,0为退出):"))
        if (i == 1):
            name = input("请输入学生姓名:")
            number = input("请输入学生学号:")
            score1 = int(input("请输入学生语文成绩:"))
            score2 = int(input("请输入学生数学成绩:"))
            score3 = int(input("请输入学生英语成绩:"))
            score4 = "学生总成绩:",score1+score2+score3
            student = {
                "姓名" : name,
                "学号" : number,
                "语文" : score1,
                "数学" : score2,
                "英语" : score3,
                "总分" : score4
            }
            students.append(student)
        else:
            break
    #按总分升序
    students.sort(key=lambda x: x["总分"],reverse=True)
    for item in students:
        print(f"姓名:{item['姓名']},学号:{item['学号']},语文:{item['语文']},数学:{item['数学']},英语:{item['英语']},总分:{item['总分']}")
def input_student(students):
    with open("student.txt","a+",encoding="utf-8") as f:
        f.write(f",录入时间:{time.strftime('%Y-%m-%d %H:%M:%S',time.localtime())}\n")
        for item in students:
            f.write(f"姓名:{item['姓名']},学号:{item['学号']},语文:{item['语文']},数学:{item['数学']},英语:{item['英语']},总分:{item['总分']}\n")
if __name__ == '__main__':
    main()
    input_student(students)

运行结果

相关推荐
嗯嗯**2 小时前
Neo4j学习2:概念、数据展示、CQL使用
数据库·学习·neo4j·数据存储·图数据库·序列化·cql
Python+JAVA+大数据2 小时前
SQL玩出算法竞赛高度!郑凌云数独算法:递归CTE+位运算DFS回溯全解析
数据库·sql·算法·搜索引擎·深度优先·dfs
TDengine (老段)2 小时前
TDengine TSDB 3.4.0.0 上线:虚拟表、流计算性能显著提升,安全能力全面进阶
大数据·数据库·物联网·安全·时序数据库·tdengine·涛思数据
Leo.yuan2 小时前
制造业常用BOM详解:单层BOM、多层BOM、工艺BOM、虚拟BOM
大数据·数据库·信息可视化·bom
筷乐老六喝旺仔2 小时前
使用Python进行PDF文件的处理与操作
jvm·数据库·python
知识分享小能手2 小时前
SQL Server 2019入门学习教程,从入门到精通,初识 SQL Server 2019 —— 语法知识点与使用方法详解(1)
数据库·学习·sqlserver
清风~徐~来2 小时前
【视频点播系统】Etcd-SDK 介绍及使用
数据库·etcd
计算机毕设VX:Fegn08952 小时前
计算机毕业设计|基于springboot + vue球鞋购物系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
仍然.2 小时前
MYSQL--- 表的设计
数据库·mysql