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)

运行结果

相关推荐
ss2734 小时前
食谱推荐系统功能测试如何写?
java·数据库·spring boot·功能测试
l1t4 小时前
DeepSeek总结的数据库外部表
数据库
m0_674294644 小时前
如何编写SQL存储过程性能对比_记录执行时间评估优化效果
jvm·数据库·python
014-code5 小时前
CompletableFuture 实战模板(超时、组合、异常链处理)
java·数据库
运气好好的5 小时前
怎样开启phpMyAdmin的操作审计日志_记录每条执行的SQL
jvm·数据库·python
それども5 小时前
DELETE 和 TRUNCATE TABLE区别
java·数据库·mysql
wenha5 小时前
数据库隔离级别
数据库·mysql·sqlserver·隔离级别
2401_871492856 小时前
Layui如何修改Layui默认的UI主题颜色(换肤功能实现)
jvm·数据库·python
Edward111111116 小时前
4.27mysql ,数据库,数据源
数据库·mysql
小徐敲java6 小时前
踩坑实录:MySQL8.0 导入SQL报错 2006 - MySQL server has gone away 完美解决
数据库·sql