【一起python】银行管理系统

news2025/1/4 13:18:59

请添加图片描述

文章目录

  • 📝计算机基础概念
  • 🌠 导入模块
  • 🌠定义`input_card_info`函数
  • 🌠 定义`check_password`函数
  • 🌠初始化用户字典和欢迎信息
    • 🌉 主循环
    • 🌉开户操作
    • 🌉查询操作
    • 🌉取款操作
    • 🌉存款操作
    • 🌉 转账操作
    • 🌉退出操作
  • 🌠完整代码
  • 🚩总结


📝计算机基础概念

以下是对上述代码各部分的详细解析:

🌠 导入模块

import random

这行代码导入了Python的random模块,用于生成随机的卡号。

🌠定义input_card_info函数

def input_card_info():
    name = input("请输入你的姓名:")
    telphone = input("请输入你的手机号:")
    idcard = input("请输入你的身份证号:")
    mima = input("请输入你的密码:")
    money = int(input("请输入你的预存金额:"))
    kahao = str(random.randint(100000, 999999))
    return kahao, mima, money, name, idcard, telphone
  • 这个函数用于获取用户开户时需要输入的各种信息,包括姓名、手机号、身份证号、密码、预存金额,并生成一个随机的卡号。
  • 最后,函数返回卡号、密码、预存金额、姓名、身份证号和手机号。

🌠 定义check_password函数

def check_password(kahao, mima, yonghu_dict):
    count = 0
    while mima not in yonghu_dict.get(kahao, {}).values():
        mima = input("你的密码错误,请重新输入:")
        count += 1
        if count == 3:
            print("该卡号被锁定!")
            return False
    return True
  • 这个函数用于检查用户输入的密码是否正确。
  • 它接受卡号、密码和用户字典作为参数。
  • 如果密码不正确,会提示用户重新输入,最多允许输入3次。如果3次输入错误,将锁定该卡号并返回False;如果密码正确,则返回True

🌠初始化用户字典和欢迎信息

yonghu_dict = {"卡号": {"密码": "123", "金额": "5"}}
print("欢迎使用本系统!")
  • 首先创建了一个初始的用户字典yonghu_dict,其中包含一个示例用户的信息(卡号、密码和金额)。
  • 然后打印欢迎信息。

🌉 主循环

while True:
    print("1.开户   2.查询   3.取款   4.存款   5.转账   6.退出")
    try:
        num = int(input("请输入你要操作的序号:"))
    except ValueError:
        print("请输入正确的整数序号!")
        continue
  • 这是一个无限循环,用于显示操作菜单并获取用户选择的操作序号。
  • 使用try - except块来捕获用户输入不是整数时的ValueError,如果发生错误,提示用户重新输入。

🌉开户操作

if num == 1:
    kahao, mima, money, name, idcard, telphone = input_card_info()
    yonghu_dict[kahao] = {"密码": mima, "金额": money}
    print("开户成功!")
    print("卡号:", kahao)
    print("密码:", mima)
    print("姓名:", name)
    print("余额:", money)
    print("身份证:", idcard)
    print("手机号:", telphone)
    print(yonghu_dict)
  • 当用户选择开户操作(num == 1)时,调用input_card_info函数获取用户信息,并将新用户信息添加到yonghu_dict字典中。
  • 然后打印开户成功信息和用户的详细信息。

🌉查询操作

elif num == 2:
    kahao = input("请输入卡号:")
    mima = input("请输入密码:")
    if kahao not in yonghu_dict:
        print("卡号输入错误!")
        continue
    if check_password(kahao, mima, yonghu_dict):
        print("你的余额为:", yonghu_dict[kahao]['金额'])
  • 当用户选择查询操作(num == 2)时,要求用户输入卡号和密码。
  • 首先检查卡号是否存在于用户字典中,如果不存在,提示错误并重新开始循环。
  • 如果卡号存在,调用check_password函数检查密码是否正确。如果密码正确,打印该卡的余额。

🌉取款操作

elif num == 3:
    kahao = input("请输入卡号:")
    mima = input("请输入密码:")
    if kahao not in yonghu_dict:
        print("卡号输入错误!")
        continue
    if check_password(kahao, mima, yonghu_dict):
        a = int(input("请输入你要取款的金额:"))
        if 0 < a <= yonghu_dict[kahao]['金额']:
            print("取款成功!")
            yonghu_dict[kahao]['金额'] -= a
        else:
            print("你要取款的金额大于你卡里的金额或取款金额小于等于0")
  • 当用户选择取款操作(num == 3)时,要求用户输入卡号和密码。
  • 首先检查卡号是否存在于用户字典中,如果不存在,提示错误并重新开始循环。
  • 如果卡号存在,调用check_password函数检查密码是否正确。如果密码正确,要求用户输入取款金额。
  • 如果取款金额大于0且小于等于卡内余额,从卡内余额中减去取款金额,并提示取款成功;否则,提示错误信息。

🌉存款操作

elif num == 4:
    kahao = input("请输入卡号:")
    mima = input("请输入密码:")
    if kahao not in yonghu_dict:
        print("卡号输入错误!")
        continue
    if check_password(kahao, mima, yonghu_dict):
        a = int(input("请输入你要存款的金额:"))
        if a > 0:
            print("存款成功!")
            yonghu_dict[kahao]['金额'] += a
        else:
            print("你要存款的金额小于等于0")
  • 当用户选择存款操作(num == 4)时,要求用户输入卡号和密码。
  • 首先检查卡号是否存在于用户字典中,如果不存在,提示错误并重新开始循环。
  • 如果卡号存在,调用check_password函数检查密码是否正确。如果密码正确,要求用户输入存款金额。
  • 如果存款金额大于0,将存款金额加到卡内余额中,并提示存款成功;否则,提示错误信息。

🌉 转账操作

elif num == 5:
    kahao = input("请输入要转出卡号:")
    mima = input("请输入密码:")
    if kahao not in yonghu_dict:
        print("卡号输入错误!")
        continue
    if check_password(kahao, mima, yonghu_dict):
        kahao1 = input("请输入要转入卡号:")
        if kahao1 not in yonghu_dict:
            print("卡号输入错误!")
            continue
        b = int(input("请输入要转出金额:"))
        if b <= yonghu_dict[kahao]['金额'] and b > 0:
            yonghu_dict[kahao]['金额'] -= b
            yonghu_dict[kahao1]['金额'] += b
            print("转账成功!")
            print("转出卡卡里余额:", yonghu_dict[kahao]['金额'])
            print("转入卡卡里余额:", yonghu_dict[kahao1]['金额'])
        else:
            print("你卡里的余额不足!")
  • 当用户选择转账操作(num == 5)时,要求用户输入转出卡号和密码。
  • 首先检查转出卡号是否存在于用户字典中,如果不存在,提示错误并重新开始循环。
  • 如果转出卡号存在,调用check_password函数检查密码是否正确。如果密码正确,要求用户输入转入卡号。
  • 检查转入卡号是否存在于用户字典中,如果不存在,提示错误并重新开始循环。
  • 如果转入卡号存在,要求用户输入转账金额。如果转账金额大于0且小于等于转出卡内余额,从转出卡内余额中减去转账金额,加到转入卡内余额中,并提示转账成功和两张卡的余额;否则,提示余额不足信息。

🌉退出操作

elif num == 6:
    break
else:
    print("请输入正确的操作序号!")
  • 当用户选择退出操作(num == 6)时,使用break语句跳出循环,结束程序。

🌠完整代码

import random

def input_card_info():
    name = input("请输入你的姓名:")
    telphone = input("请输入你的手机号:")
    idcard = input("请输入你的身份证号:")
    mima = input("请输入你的密码:")
    money = int(input("请输入你的预存金额:"))
    kahao = str(random.randint(100000, 999999))
    return kahao, mima, money, name, idcard, telphone


def check_password(kahao, mima, yonghu_dict):
    count = 0
    while mima not in yonghu_dict.get(kahao, {}).values():
        mima = input("你的密码错误,请重新输入:")
        count += 1
        if count == 3:
            print("该卡号被锁定!")
            return False
    return True


yonghu_dict = {"卡号": {"密码": "123", "金额": "5"}}
print("欢迎使用本系统!")
while True:
    print("1.开户   2.查询   3.取款   4.存款   5.转账   6.退出")
    try:
        num = int(input("请输入你要操作的序号:"))
    except ValueError:
        print("请输入正确的整数序号!")
        continue

    if num == 1:
        kahao, mima, money, name, idcard, telphone = input_card_info()
        yonghu_dict[kahao] = {"密码": mima, "金额": money}
        print("开户成功!")
        print("卡号:", kahao)
        print("密码:", mima)
        print("姓名:", name)
        print("余额:", money)
        print("身份证:", idcard)
        print("手机号:", telphone)
        print(yonghu_dict)
    elif num == 2:
        kahao = input("请输入卡号:")
        mima = input("请输入密码:")
        if kahao not in yonghu_dict:
            print("卡号输入错误!")
            continue
        if check_password(kahao, mima, yonghu_dict):
            print("你的余额为:", yonghu_dict[kahao]['金额'])
    elif num == 3:
        kahao = input("请输入卡号:")
        mima = input("请输入密码:")
        if kahao not in yonghu_dict:
            print("卡号输入错误!")
            continue
        if check_password(kahao, mima, yonghu_dict):
            a = int(input("请输入你要取款的金额:"))
            if 0 < a <= yonghu_dict[kahao]['金额']:
                print("取款成功!")
                yonghu_dict[kahao]['金额'] -= a
            else:
                print("你要取款的金额大于你卡里的金额或取款金额小于等于0")
    elif num == 4:
        kahao = input("请输入卡号:")
        mima = input("请输入密码:")
        if kahao not in yonghu_dict:
            print("卡号输入错误!")
            continue
        if check_password(kahao, mima, yonghu_dict):
            a = int(input("请输入你要存款的金额:"))
            if a > 0:
                print("存款成功!")
                yonghu_dict[kahao]['金额'] += a
            else:
                print("你要存款的金额小于等于0")
    elif num == 5:
        kahao = input("请输入要转出卡号:")
        mima = input("请输入密码:")
        if kahao not in yonghu_dict:
            print("卡号输入错误!")
            continue
        if check_password(kahao, mima, yonghu_dict):
            kahao1 = input("请输入要转入卡号:")
            if kahao1 not in yonghu_dict:
                print("卡号输入错误!")
                continue
            b = int(input("请输入要转出金额:"))
            if b <= yonghu_dict[kahao]['金额'] and b > 0:
                yonghu_dict[kahao]['金额'] -= b
                yonghu_dict[kahao1]['金额'] += b
                print("转账成功!")
                print("转出卡卡里余额:", yonghu_dict[kahao]['金额'])
                print("转入卡卡里余额:", yonghu_dict[kahao1]['金额'])
            else:
                print("你卡里的余额不足!")
    elif num == 6:
        break
    else:
        print("请输入正确的操作序号!")

🚩总结

请添加图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2269257.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【D3.js in Action 3 精译_047】5.2:图形的堆叠(一)—— 图解 D3 中的堆叠布局生成器

当前内容所在位置&#xff1a; 第五章 饼图布局与堆叠布局 ✔️ 5.1 饼图和环形图的创建 5.1.1 准备阶段&#xff08;一&#xff09;5.1.2 饼图布局生成器&#xff08;二&#xff09;5.1.3 圆弧的绘制&#xff08;三&#xff09;5.1.4 数据标签的添加&#xff08;四&#xff09…

自建私有云相册:Docker一键部署Immich,照片视频备份利器

自建私有云相册&#xff1a;Docker一键部署Immich&#xff0c;照片视频备份利器 前言 随着人们手机、PC、平板等电子产品多样&#xff0c;我们拍摄和保存的照片和视频数量也在不断增加。如何高效地管理和备份这些珍贵的记忆成为了一个重要的问题。 传统的云备份虽然方便&…

[微服务] - MQ高级

在昨天的练习作业中&#xff0c;我们改造了余额支付功能&#xff0c;在支付成功后利用RabbitMQ通知交易服务&#xff0c;更新业务订单状态为已支付。 但是大家思考一下&#xff0c;如果这里MQ通知失败&#xff0c;支付服务中支付流水显示支付成功&#xff0c;而交易服务中的订单…

【Unity3D】A*寻路(2D究极简单版)

运行后点击透明格子empty即执行从(0,0)起点到点击为止终点&#xff08;测试是(5,5)&#xff09;如下图 UICamera深度要比MainCamera大&#xff0c;Clear Flags:Depth only&#xff0c;正交视野 MainCamera保持原样&#xff1b;注意Line绘线物体的位置大小旋转信息&#xff0c;不…

xadmin后台首页增加一个导入数据按钮

xadmin后台首页增加一个导入数据按钮 效果 流程 1、在添加小组件中添加一个html页面 2、写入html代码 3、在urls.py添加导入数据路由 4、在views.py中添加响应函数html代码 <!DOCTYPE html> <html lang

压敏电阻MOV选型【EMC】

左侧的压敏电阻用来防护差模干扰&#xff1b;右侧并联在L N 两端的压敏电阻是用来防护共模干扰&#xff1a; 选择压敏电阻时&#xff0c;通常需要考虑以下几个关键因素&#xff0c;以确保它能够有效保护电路免受浪涌电流或过电压的损害&#xff0c;同时满足 EMC 要求&#xff1…

pycharm pytorch tensor张量可视化,view as array

Evaluate Expression 调试过程中&#xff0c;需要查看比如attn_weight 张量tensor的值。 方法一&#xff1a;attn_weight.detach().numpy(),view as array 方法二&#xff1a;attn_weight.cpu().numpy(),view as array

log4j2的Strategy、log4j2的DefaultRolloverStrategy、删除过期文件

文章目录 一、DefaultRolloverStrategy1.1、DefaultRolloverStrategy节点1.1.1、filePattern属性1.1.2、DefaultRolloverStrategy删除原理 1.2、Delete节点1.2.1、maxDepth属性 二、知识扩展2.1、DefaultRolloverStrategy与Delete会冲突吗&#xff1f;2.1.1、场景一&#xff1a…

设计模式之访问者模式:一楼千面 各有玄机

~犬&#x1f4f0;余~ “我欲贱而贵&#xff0c;愚而智&#xff0c;贫而富&#xff0c;可乎&#xff1f; 曰&#xff1a;其唯学乎” 一、访问者模式概述 \quad 江湖中有一个传说&#xff1a;在遥远的东方&#xff0c;有一座神秘的玉楼。每当武林中人来访&#xff0c;楼中的各个房…

结合实例来聊聊UDS诊断中的0x2F服务

1、什么是UDS中的0x2F服务 0x2F简单来说&#xff0c;就是输入输出控制服务。先看官方的简绍 翻译如下&#xff1a; InputOutputControlByldentifier服务来替换输入信号、内部服务器函数和/或强制控制为电子系统的输出&#xff08;执行器&#xff09;的值。通常&#xff0c;此…

1月第二讲:WxPython跨平台开发框架之图标选择界面

1、图标分类介绍 这里图标我们分为两类&#xff0c;一类是wxPython内置的图标资源&#xff0c;以wx.Art_开始。wx.ART_ 是 wxPython 提供的艺术资源&#xff08;Art Resource&#xff09;常量&#xff0c;用于在界面中快速访问通用的图标或位图资源。这些资源可以通过 wx.ArtP…

【弱监督视频异常检测】2024-TCSVT-基于片段间特征相似度的多尺度时间 MLP 弱监督视频异常检测

2024-TCSVT-Inter-clip Feature Similarity based Weakly Supervised Video Anomaly Detection via Multi-scale Temporal MLP 基于片段间特征相似度的多尺度时间 MLP 弱监督视频异常检测摘要1. 引言2. 相关工作A. 分布外检测B. 弱监督视频异常检测C. 多层感知器 3. 方法A. 概述…

C# OpenCV机器视觉:凸包检测

在一个看似平常却又暗藏玄机的午后&#xff0c;阿强正悠闲地坐在实验室里&#xff0c;翘着二郎腿&#xff0c;哼着小曲儿&#xff0c;美滋滋地品尝着手中那杯热气腾腾的咖啡&#xff0c;仿佛整个世界都与他无关。突然&#xff0c;实验室的门 “砰” 的一声被撞开&#xff0c;小…

【英特尔IA-32架构软件开发者开发手册第3卷:系统编程指南】2001年版翻译,2-44

文件下载与邀请翻译者 学习英特尔开发手册&#xff0c;最好手里这个手册文件。原版是PDF文件。点击下方链接了解下载方法。 讲解下载英特尔开发手册的文章 翻译英特尔开发手册&#xff0c;会是一件耗时费力的工作。如果有愿意和我一起来做这件事的&#xff0c;那么&#xff…

8.若依系统监控与定时任务

帮助开发者和运维快速了解应用程序的性能状态。 数据监控 定时任务 实现动态管理任务。 需求&#xff1a;每间隔5s&#xff0c;控制台输出系统时间。 新建的任务类必须在指定目录ruoyi-quartz模块下的task包下。 状态设置为启动 执行策略 场景&#xff1a;比如一个任务每个…

【JAVA高级篇教学】第六篇:Springboot实现WebSocket

在 Spring Boot 中对接 WebSocket 是一个常见的场景&#xff0c;通常用于实现实时通信。以下是一个完整的 WebSocket 集成步骤&#xff0c;包括服务端和客户端的实现。本期做个简单的测试用例。 目录 一、WebSocket 简介 1. 什么是 WebSocket&#xff1f; 2. WebSocket 的特…

【YOLO 项目实战】(12)红外/可见光多模态目标检测

欢迎关注『youcans动手学模型』系列 本专栏内容和资源同步到 GitHub/youcans 【YOLO 项目实战】&#xff08;10&#xff09;YOLO8 环境配置与推理检测 【YOLO 项目实战】&#xff08;11&#xff09;YOLO8 数据集与模型训练 【YOLO 项目实战】&#xff08;12&#xff09;红外/可…

Ubuntu开机The root filesystem on /dev/sdbx requires a manual fsck 问题

出现“Manual fsck”错误可能由以下几种原因引起&#xff1a; 不正常关机&#xff1a;如果系统意外断电或被强制重启&#xff0c;文件系统可能未能正确卸载&#xff0c;导致文件系统损坏。磁盘故障&#xff1a;硬盘的物理损坏可能会引发文件系统错误。文件系统配置问题&#x…

RFSOC 47dr Dp口测试(ARM裸机)

47DR 内核还是一个4核A53的MPSOC&#xff0c;测试方式和MPSOC一样 首先设置好BD文件 编译好BIT设置VITIS工程 examle工程测试即可 但是本人硬件会跑飞不知道为何&#xff0c;通过注释掉下图的子函数得以解决 值得注意的是&#xff0c;最好用HP的线&#xff0c;不要用DP转…

protobuf: 通讯录2.1

先引入需要知道的proto3语法&#xff1a; 1.proto3 1.hexdump 作用&#xff1a; hexdump&#xff1a;是Linux下的⼀个⼆进制⽂件查看⼯具&#xff0c;它可以将⼆进制⽂件转换为ASCII、⼋进制、 ⼗进制、⼗六进制格式进⾏查看。 -C: 表⽰每个字节显⽰为16进制和相应的ASCI…