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)

运行结果

相关推荐
柒.梧.几秒前
MySQL核心考点:存储引擎区别+视图详解
数据库·mysql·面试
电商API&Tina几秒前
跨境电商如何接入1688官方寻源通接口?附接入流程
java·数据库·python·sql·oracle·json·php
明月_清风9 分钟前
🚀 Flyway 存量数据库迁移:50张表一键导出清洗实战(附完整脚本)
数据库·后端
羊小蜜.17 分钟前
Mysql 08: 数据表基本操作——从创建到约束
数据库·mysql·数据表
程序员小郭8318 分钟前
MySQL分库分表策略全解析(实战版)
数据库·mysql·架构
卓怡学长20 分钟前
m320基于Java的网络音乐系统的设计与实现
java·数据库·spring·tomcat·maven
爱浦路 IPLOOK44 分钟前
选对UPF网元供应商,解锁5G-A时代行业赋能新可能
运维·网络·数据库
Elastic 中国社区官方博客1 小时前
将 Logstash 管道从 Azure Event Hubs 迁移到 Kafka 输入插件
大数据·数据库·elasticsearch·microsoft·搜索引擎·kafka·azure
草莓熊Lotso1 小时前
MySQL 事务管理全解:从 ACID 特性、隔离级别到 MVCC 底层原理
linux·运维·服务器·c语言·数据库·c++·mysql
鸽芷咕1 小时前
Oracle 替代工程实践深度解析:金仓全链路工程实践 —— 从评估决策到平滑上线的深度技术攻坚
数据库·oracle