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)

运行结果

相关推荐
weelinking1 天前
【产品】00_产品经理用Claude实现产品系列介绍
数据库·人工智能·sql·数据挖掘·github·产品经理
2301_803934611 天前
Go语言如何做网络爬虫_Go语言爬虫开发教程【指南】
jvm·数据库·python
秋91 天前
windows中安装redis
数据库·redis·缓存
Cosolar1 天前
万字详解:RAG 向量索引算法与向量数据库架构及实战
数据库·人工智能·算法·数据库架构·milvus
想唱rap1 天前
IO多路转接之poll
服务器·开发语言·数据库·c++
SeaTunnel1 天前
AI 让 SeaTunnel 读源码和调试过时了吗?
大数据·数据库·人工智能·apache·seatunnel·数据同步
凯瑟琳.奥古斯特1 天前
数据冗余与规范化的本质[数据库原理]
开发语言·数据库·职场和发展
_ku_ku_1 天前
数据库系统原理 · SQL 数据定义、更新及数据库编程 · 自学总结
数据库·oracle
Mortalbreeze1 天前
深度理解文件系统 ---- 从磁盘存储到内核存储
大数据·linux·数据库
2301_803934611 天前
MySQL 字段类型选择规范指南
jvm·数据库·python