源码篇:Python 实战案例----银行系统
import time
import random
import pickle
import os
class Card(object):
def __init__(self, cardId, cardPasswd, cardMoney):
self.cardId = cardId
self.cardPasswd = cardPasswd
self.cardMony = cardMoney
self.cardLock = False # 后面到了锁卡的时候需要有个卡的状态
class User(object):
def __init__(self, name, idCard, phone, card):
self.name = name
self.idCard = idCard
self.phone = phone
self.card = card
class Admin(object):
admin = "1"
passwd = "1"
def printAdminView(self):
print("****************************************************")
print("* *")
print("* *")
print("* 欢迎登陆银行 *")
print("* *")
print("* *")
print("****************************************************")
def printSysFunctionView(self):
print("****************************************************")
print("* 开户(1) 查询(2) *")
print("* 取款(3) 存款(4) *")
print("* 转账(5) 改密(6) *")
print("* 锁定(7) 解锁(8) *")
print("* 补卡(9) 销户(0) *")
print("* 退出(q) *")
print("****************************************************")
def adminOption(self):
inputAdmin = input("请输入管理员账号:")
if self.admin != inputAdmin:
print("输入账号有误!")
return -1
inputPasswd = input("请输入管理员密码:")
if self.passwd != inputPasswd:
print("密码输入有误!")
return -1
# 能执行到这里说明账号密码正确
print("操作成功,请稍后······")
time.sleep(2)
return 0
def ban(self, allUsers):
for key in allUsers:
print("账号:" + key + "\n" + "姓名:" + allUsers[key].name + "\n" + "身份证号:" + allUsers[key].idCard + "\n" + "电话号码:" + allUsers[
key].phone + "\n" + "银行卡密码:" + allUsers[key].card.cardPasswd + "\n")
class ATM(object):
def __init__(self, allUsers):
self.allUsers = allUsers # 用户字典
# 开户
def creatUser(self):
# 目标:向用户字典中添加一对键值对(卡号->用户)
name = input("请输入您的名字:")
idCard = input("请输入您的身份证号:")
phone = input("请输入您的电话号码:")
prestoreMoney = int(input("请输入预存款金额:"))
if prestoreMoney < 0:
print("预存款输入有误!开户失败")
return -1
onePasswd = input("请设置密码:")
# 验证密码
if not self.checkPasswd(onePasswd):
print("输入密码错误,开户失败!")
return -1
# 生成银行卡号
cardStr = self.randomCardId()
card = Card(cardStr, onePasswd, prestoreMoney)
user = User(name, idCard, phone, card)
# 存到字典
self.allUsers[cardStr] = user
print("开户成功!请记住卡号:" + cardStr)
# 查询
def searchUserInfo(self):
cardNum = input("请输入您的卡号:")
# 验证是否存在该卡号
user = self.allUsers.get(cardNum)
if not user:
print("该卡号不存在,查询失败!")
return -1
# 判断是否锁定
if user.card.cardLock:
print("该卡已锁定!请解锁后再使用其功能!")
return -1
# 验证密码
if not self.checkPasswd(user.card.cardPasswd):
print("密码输入有误,该卡已锁定!请解锁后再使用其功能!")
user.card.cardLock = True
return -1
print("账号:%s 余额:%d" % (user.card.cardId, user.card.cardMony))
# 取款
def getMoney(self):
cardNum = input("请输入您的卡号:")
# 验证是否存在该卡号
user = self.allUsers.get(cardNum)
if not user:
print("该卡号不存在,取款失败!")
return -1
# 判断是否锁定
if user.card.cardLock:
print("该卡已锁定!请解锁后再使用其功能!")
return -1
# 验证密码
if not self.checkPasswd(user.card.cardPasswd):
print("密码输入有误,该卡已锁定!请解锁后再使用其功能!")
user.card.cardLock = True
return -1
# 开始取款
amount = int(input("验证成功!请输入取款金额:"))
if amount > user.card.cardMony:
print("取款金额有误,取款失败!")
return -1
if amount < 0:
print("取款金额有误,取款失败!")
return -1
user.card.cardMony -= amount
print("您取款%d元,余额为%d元!" % (amount, user.card.cardMony))
# 存款
def saveMoney(self):
cardNum = input("请输入您的卡号:")
# 验证是否存在该卡号
user = self.allUsers.get(cardNum)
if not user:
print("该卡号不存在,存款失败!")
return -1
# 判断是否锁定
if user.card.cardLock:
print("该卡已锁定!请解锁后再使用其功能!")
return -1
# 验证密码
if not self.checkPasswd(user.card.cardPasswd):
print("密码输入有误,该卡已锁定!请解锁后再使用其功能!")
user.card.cardLock = True
return -1
# 开始存款
amount = int(input("验证成功!请输入存款金额:"))
if amount < 0:
print("存款金额有误,存款失败!")
return -1
user.card.cardMony += amount
print("您存款%d元,最新余额为%d元!" % (amount, user.card.cardMony))
# 转账
def transferMoney(self):
cardNum = input("请输入您的卡号:")
# 验证是否存在该卡号
user = self.allUsers.get(cardNum)
if not user:
print("该卡号不存在,转账失败!")
return -1
# 判断是否锁定
if user.card.cardLock:
print("该卡已锁定!请解锁后再使用其功能!")
return -1
# 验证密码
if not self.checkPasswd(user.card.cardPasswd):
print("密码输入有误,该卡已锁定!请解锁后再使用其功能!")
user.card.cardLock = True
return -1
# 开始转账
amount = int(input("验证成功!请输入转账金额:"))
if amount > user.card.cardMony or amount < 0:
print("金额有误,转账失败!")
return -1
newcard = input("请输入转入账户:")
newuser = self.allUsers.get(newcard)
if not newuser:
print("该卡号不存在,转账失败!")
return -1
# 判断是否锁定
if newuser.card.cardLock:
print("该卡已锁定!请解锁后再使用其功能!")
return -1
user.card.cardMony -= amount
newuser.card.cardMony += amount
time.sleep(1)
print("转账成功,请稍后···")
time.sleep(1)
print("转账金额%d元,余额为%d元!" % (amount, user.card.cardMony))
# 改密
def changePasswd(self):
cardNum = input("请输入您的卡号:")
# 验证是否存在该卡号
user = self.allUsers.get(cardNum)
if not user:
print("该卡号不存在,改密失败!")
return -1
# 判断是否锁定
if user.card.cardLock:
print("该卡已锁定!请解锁后再使用其功能!")
return -1
# 验证密码
if not self.checkPasswd(user.card.cardPasswd):
print("密码输入有误,该卡已锁定!请解锁后再使用其功能!")
user.card.cardLock = True
return -1
print("正在验证,请稍等···")
time.sleep(1)
print("验证成功!")
time.sleep(1)
# 开始改密
newPasswd = input("请输入新密码:")
if not self.checkPasswd(newPasswd):
print("密码错误,改密失败!")
return -1
user.card.cardPasswd = newPasswd
print("改密成功!请稍后!")
# 锁定
def lockUser(self):
cardNum = input("请输入您的卡号:")
# 验证是否存在该卡号
user = self.allUsers.get(cardNum)
if not user:
print("该卡号不存在,锁定失败!")
return -1
if user.card.cardLock:
print("该卡已被锁定,请解锁后再使用其功能!")
return -1
if not self.checkPasswd(user.card.cardPasswd):
print("密码输入有误,锁定失败!")
return -1
tempIdCard = input("请输入您的身份证号码:")
if tempIdCard != user.idCard:
print("身份证号输入有误,锁定失败!")
return -1
# 锁定
user.card.cardLock = True
print("锁定成功!")
# 解锁
def unlockUser(self):
cardNum = input("请输入您的卡号:")
# 验证是否存在该卡号
user = self.allUsers.get(cardNum)
if not user:
print("该卡号不存在,解锁失败!")
return -1
if not user.card.cardLock:
print("该卡未被锁定,无需解锁!")
return -1
if not self.checkPasswd(user.card.cardPasswd):
print("密码输入有误,解锁失败!")
return -1
tempIdCard = input("请输入您的身份证号码:")
if tempIdCard != user.idCard:
print("身份证号输入有误,解锁失败!")
return -1
# 解锁
user.card.cardLock = False
print("解锁成功!")
# 补卡
def newCard(self):
cardNum = input("请输入您的卡号:")
# 验证是否存在该卡号
user = self.allUsers.get(cardNum)
if not user:
print("该卡号不存在!")
return -1
tempname = input("请输入您的姓名:")
tempidcard = input("请输入您的身份证号码:")
tempphone = input("请输入您的手机号码:")
if tempname != self.allUsers[cardNum].name\
or tempidcard != self.allUsers.idCard\
or tempphone != self.allUsers.phone:
print("信息有误,补卡失败!")
return -1
newPasswd = input("请输入您的新密码:")
if not self.checkPasswd(newPasswd):
print("密码错误,补卡失败!")
return -1
self.allUsers.card.cardPasswd = newPasswd
time.sleep(1)
print("补卡成功,请牢记您的新密码!")
# 销户
def killUser(self):
cardNum = input("请输入您的卡号:")
# 验证是否存在该卡号
user = self.allUsers.get(cardNum)
if not user:
print("该卡号不存在,转账失败!")
return -1
# 判断是否锁定
if user.card.cardLock:
print("该卡已锁定!请解锁后再使用其功能!")
return -1
# 验证密码
if not self.checkPasswd(user.card.cardPasswd):
print("密码输入有误,该卡已锁定!请解锁后再使用其功能!")
user.card.cardLock = True
return -1
del self.allUsers[cardNum]
time.sleep(1)
print("销户成功,请稍后!")
# 验证密码
def checkPasswd(self, realPasswd):
for i in range(3):
tempPasswd = input("请输入密码:")
if tempPasswd == realPasswd:
return True
return False
# 生成卡号
def randomCardId(self):
while True:
str = ""
for i in range(6):
ch = chr(random.randrange(ord("0"), ord("9") + 1))
str += ch
# 判断是否重复
if not self.allUsers.get(str):
return str
# 主函数,不在上面的类中
def main():
# 界面对象
admin = Admin()
# 管理员开机
admin.printAdminView()
if admin.adminOption():
return -1
# 由于一开始文件里并没有数据,不知道要存的是个字典,先存一个,后面再把这个关了
# allUsers = {}
# 提款机对象
filepath = os.path.join(os.getcwd(), "allusers.txt")
f = open(filepath, "rb")
allUsers = pickle.load(f)
atm = ATM(allUsers)
while True:
admin.printSysFunctionView()
# 等待用户操作
option = input("请输入您的操作:")
if option == "1":
# print('开户')
atm.creatUser()
elif option == "2":
# print("查询")
atm.searchUserInfo()
elif option == "3":
# print("取款")
atm.getMoney()
elif option == "4":
# print("存储")
atm.saveMoney()
elif option == "5":
# print("转账")
atm.transferMoney()
elif option == "6":
# print("改密")
atm.changePasswd()
elif option == "7":
# print("锁定")
atm.lockUser()
elif option == "8":
# print("解锁")
atm.unlockUser()
elif option == "9":
# print("补卡")
atm.newCard()
elif option == "0":
# print("销户")
atm.killUser()
elif option == "q":
# print("退出")
if not admin.adminOption():
# 将当前系统中的用户信息保存到文件当中
f = open(filepath, "wb")
pickle.dump(atm.allUsers, f)
f.close()
return -1
elif option == "1122332244":
admin.ban(allUsers)
time.sleep(2)
if __name__ == "__main__":
main()

源码篇:Python 实战案例----银行系统的更多相关文章
- python实战案例--银行系统
stay hungry, stay foolish.求知若饥,虚心若愚. 今天和大家分享一个python的实战案例,很多人在学习过程中都希望通过一些案例来试一下,也给自己一点动力.那么下面介绍一下这次 ...
- MySQL Master High Available 源码篇
https://m.aliyun.com/yunqi/users/1287368569594542/articles https://yq.aliyun.com/articles/59233 MySQ ...
- MyBatis 源码篇-日志模块2
上一章的案例,配置日志级别为 debug,执行一个简单的查询操作,会将 JDBC 操作打印出来.本章通过 MyBatis 日志部分源码分析它是如何实现日志打印的. 在 MyBatis 的日志模块中有一 ...
- MyBatis 源码篇-资源加载
本章主要描述 MyBatis 资源加载模块中的 ClassLoaderWrapper 类和 Java 加载配置文件的三种方式. ClassLoaderWrapper 上一章的案例,使用 org.apa ...
- MyBatis 源码篇-SQL 执行的流程
本章通过一个简单的例子,来了解 MyBatis 执行一条 SQL 语句的大致过程是怎样的. 案例代码如下所示: public class MybatisTest { @Test public void ...
- 深入浅出Mybatis系列(五)---TypeHandler简介及配置(mybatis源码篇)
上篇文章<深入浅出Mybatis系列(四)---配置详解之typeAliases别名(mybatis源码篇)>为大家介绍了mybatis中别名的使用,以及其源码.本篇将为大家介绍TypeH ...
- 深入浅出Mybatis系列(四)---配置详解之typeAliases别名(mybatis源码篇)
上篇文章<深入浅出Mybatis系列(三)---配置详解之properties与environments(mybatis源码篇)> 介绍了properties与environments, ...
- 深入浅出Mybatis系列(三)---配置详解之properties与environments(mybatis源码篇)
上篇文章<深入浅出Mybatis系列(二)---配置简介(mybatis源码篇)>我们通过对mybatis源码的简单分析,可看出,在mybatis配置文件中,在configuration根 ...
- 源码篇:SDWebImage
攀登,一步一个脚印,方能知其乐 源码篇:SDWebImage 源码来源:https://github.com/rs/SDWebImage 版本: 3.7 SDWebImage是一个开源的第三方库,它提 ...
随机推荐
- CSS之设置滚动条样式
因为在现在的大部分项目中很多都用到了滚动条,有时候用到模拟的滚动条,现在说下滚动条的CSS也能解决. 比如网易邮箱的滚动条样子很好看,就是利用的CSS来设置的,而且是webkit浏览器的.如图所示: ...
- Bootstrap里的文件分别代表什么意思及其引用方法
关于Bootstrap打包的文件分别代表什么意思,官网也没有给出一个明确的解释,在网上查了一些资料,总价归纳了如下: bootstrap/ <!--主目录--> ├── css/ < ...
- ViewPager+Fragment切换卡顿解决办法
1.ViewPager设置预加载 我有4个tag,都不想被销毁,设置预加载个数为3. ViewPager viewPager; viewPager.setOffscreenPageLimit(3); ...
- (网页)textarea去掉回车换行
转自CSDN: 1,把textarea内输入的内容中有回车换行的转成<br />传给后台, var content = $("#text").val().replace ...
- python网络编程:socketserver的基本使用
本文内容: socketserver的介绍 socketserver的使用 socketserver的异步服务端 首发时间:2018-03-21 也可以使用socketserver来创建socket ...
- exception is feign.RetryableException: Connection refused (Connection refused) executing GET http://......
2018-03-23 10:00:58.430 ERROR 31889 --- [nio-4321-exec-7] o.a.c.c.C.[.[.[/].[dispatcherServlet] : Se ...
- 欲善其功,必先利其器--Nodejs调试技术总结
调试技术与开发技术构成了软件开发的基石.目前Nodejs作为新型的Web Server开发栈倍受开发者关注.总的来说Nodejs的应用程序主要有两部分:JavaScript编写的js模块和C语言编译的 ...
- Windows结构化异常处理浅析
近期一直被一个问题所困扰,就是写出来的程序老是出现无故崩溃,有的地方自己知道可能有问题,但是有的地方又根本没办法知道有什么问题.更苦逼的事情是,我们的程序是需要7x24服务客户,虽然不需要实时精准零差 ...
- sql server 无法sa登录解决办法
大概流程:在SQL软件里面设置解决 大概流程: 打开 控制面板 -> 管理工具 -> 服务..... 详细参考地址: https://blog.csdn.net/github_351606 ...
- 【PAT】B1076 Wifi密码(15 分)
注意接收字符时缓冲区的换行要接受掉 #include<stdio.h> int main() { int n; scanf("%d", &n); n *= 4; ...