问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

用python创建一个银行类, 这个类实现了:1、可以将用户信息写入到文件...

发布网友 发布时间:2022-04-26 20:37

我来回答

3个回答

懂视网 时间:2022-05-10 13:43

前言

在进行一个应用系统的开发过程中,从上到下一般需要四个构件:客户端-业务逻辑层-数据访问层-数据库,其中数据访问层是一个底层、核心的技术。而且在实际开发中,数据库的操作也就是说数据访问层都是嵌套在其他语言中的,其是编程的核心。本文面向的是python语言,即通过python操作数据库来实现简单的银行转账操作。

工具

python提供了python DB API用来统一操作数据库,使访问数据库的接口规范化,在没有python DB API之前,接口程序十分混乱,不同的数据库需要不同的操作接口,所以这个接口提供了极大的方便。在具体操作的时候,我们需要操作数据库以及其他逻辑的python代码,数据库连接对象connection来建立连接,数据库交互对象cursor来“运送”数据,一个健壮的系统必不可少的便是数据库异常类Exceptions。整个访问数据库流程如下图:

Python实现一个简单的银行转账操作方法

接下来分别介绍下两个主要对象:

connection:数据库连接对象,建立python客户端与数据库的网络连接。
创建方法:MySQLdb.connect(),包括的主要成员方法:
cursor():使用该连接创建并返回游标
commit():提交当前事务
rollback():回滚当前事务
close()关闭连接
cursor:游标对象,用于执行查询与获取结果,cursor对象支持的主要方法如下:
execute():执行SQL语句,将结果从数据库获取到客户端
fetchone():取得结果集的下一行
fetchmany(size):获取结果集的下size行
fetchall():获取结果集中剩下的所有行
rowcount:最近一次execute返回数据的行数
close():关闭游标对象
在上面的方法中提到了一个关键名词:事务,什么是事务呢?他是访问和更新数据的一个程序执行单元,很多操作的一个集合,有四个特点:

原子性:事物中包括的诸操作要么都做,要么都不做
一致性:事务必须使数据库从一致性状态变到另一个一致性状态
隔离型:一个事务的执行不被其他事务干扰
持久性:事务一旦提交,它对数据库的改变就是持久性的
事务的上述特点正是我们完成银行转账操作的关键。

具体实现

在开发中我们怎么样使用事务呢?

关闭自动commit()
正常结束事务:conn.commit(),
异常结束事务:conn.rollback()
在银行转账系统中,需要考虑如下需求:比如A给B转账,当A账户上减少了M钱时,必须在B账户上多了M钱,不能A减了B没加,也不能B加了A还没有减,当然账户必须是有效的,M钱的金额肯定要大于A账户上的金额。所以在具体设计的时候,需要将A账户的金钱减少和B账户的金钱增加作为一个事务,要么同时成功,要么一起失败。按照这个需求,书写代码,详细代码见github,代码复制和数据库如下,有两个账户,分别拥有金钱110和10,在运行代码的时候在参数栏输入1,2,100(source_acctid, target_acctid, tranfer_money)。

Python实现一个简单的银行转账操作方法

整个代码的逻辑如下:首先连接数据库,之后执行逻辑,然后断开数据库连接,执行的逻辑包括检查转账双方的账户是否有效,转账金额是否多于转账人的账户余额,分别给转账双方的帐号金额发生变化。如果正常结束事务,提交修改数据库,否则回滚。

#coding:utf-8
import sys
import MySQLdb
class TransferMoney():
def __init__(self, conn):
self.conn = conn
def transfer(self, src, target, money):
try:
self.check_acct_available(src)
self.check_acct_available(target)
self.has_enough_money(src, money)
self.reduce_money(src, money)
self.add_money(target, money)
self.conn.commit()
except Exception as e:
print e
self.conn.rollback()
def reduce_money(self, src, money):
cursor = self.conn.cursor()
try:
sql = "update account set money = money - %s where acctid = %s" %(money, src)
cursor.execute(sql)
print "reduce_money: " + sql
#rs = cursor.fetchall()
if cursor.rowcount != 1:
raise Exception("the account reduce money fail")
finally:
cursor.close()
def add_money(self, target, money):
cursor = self.conn.cursor()
try:
sql = "update account set money = money + %s where acctid = %s" %(money, target)
cursor.execute(sql)
print "add_money: " + sql
#rs = cursor.fetchall()
if cursor.rowcount != 1:
raise Exception("the account add money fail")
finally:
cursor.close()
def check_acct_available(self, accit):
cursor = self.conn.cursor()
try:
sql = "select * from account where acctid = %s" %accit
cursor.execute(sql)
print "check_acct_available: " + sql
rs = cursor.fetchall()
if len(rs) != 1:
raise Exception("the account %s is not exist" %accit)
finally:
cursor.close()
def has_enough_money(self, src, money):
cursor = self.conn.cursor()
try:
sql = "select * from account where acctid = %s and money >= %s " %(src, money)
cursor.execute(sql)
print "has_enough_money: " + sql
rs = cursor.fetchall()
if len(rs) != 1:
raise Exception("the account does not have enough money")
finally:
cursor.close()
if __name__ == "__main__":
source_acctid = sys.argv[1]
target_acctid = sys.argv[2]
money = sys.argv[3]
conn = MySQLdb.connect(
host = "127.0.0.1", user = '******', passwd = '******', port = 3306, db = '******'
)
tr_money = TransferMoney(conn)
try:
tr_money.transfer(source_acctid, target_acctid, money)
except Exception as e:
print e
finally:
conn.close()

总结

通过对数据库的操作就可以实现一个简单的银行转账系统,所以在系统开发的时候,我们应该尽最大的可能,让整个系统不只是多个组件的拼接,应该实现1+1>2。

更多Python实现一个简单的银行转账操作方法相关文章请关注PHP中文网!

热心网友 时间:2022-05-10 10:51

class bank(object):
    def write(self,user_info):
    with open('user.txt','a') as f:
    f.write(user_info+'\n')
    def read(self):
        with open('user.txt','r') as f:
        txt=f.read()
        print(txt.strip('\n'))
a=bank()
a.write('12312312312312312312312,12312312312312,213213123')
a.write('12312312312312312312312,12312312312312,213213123')
a.write('12312312312312312312312,12312312312312,213213123')
a.write('12312312312312312312312,12312312312312,213213123')
a.write('12312312312312312312312,12312312312312,213213123')
a.read()

热心网友 时间:2022-05-10 12:09

class bank():
    def __init__(self):
        self.user_info = []
    def get_user_info(self,info):
        self.user_info.append(info)
    def wtuser(self):
        with open('user.txt','w') as f:
            for i in self.user_info:
                f.write(str(i))
                f.write('\n')
            f.close()
    def rser(self):
        with open('user.txt','r') as f:
            s = 1
            while s:
                s = f.readline()
                if s not in self.user_info:
                    self.user_info.append(s)
            f.close()

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
临沂比较有名的男装品牌 呼伦贝尔市悦动网络科技有限公司怎么样? 呼伦贝尔中汇实业有限公司怎么样? 呼伦贝尔油玉不绝电子商务有限公司怎么样? 如何避免wps卡顿? 属鼠的男人找对象是属什么,属鼠的人和什么属相合 96年鼠的姻缘在哪年 属相相合年份运势提升 2024属鼠找对象属什么最佳 黑客攻击网站能报案吗 黑客攻击报案有用吗 python如何创建用户输入的数量的list? 如何利用python在linux上添加用户,并修改密码 如何使用python语言实现用户登录系统 XIBO-X8型号的手机下载手机管家还是360安全卫士比较好点 python自定义输入用户名和密码如何写到oracl数据库中 百度卫士,腾讯手机管家,360哪个比较好,或者还有其他更好的吗? 360手机助手怎么样 博学谷Python系列教程之Linux基础-70-新建用户useradd和passwd Python2.7脚本在Linux怎么实现创建多用户? 手机令牌保护DNF安全吗? 怎么用python写用户选择哪个程序就用哪个程序 手机想装安全软件,QQ,管家和360我应该选哪个? 36手机卫士和腾讯手机管家哪个好? s60v5版本的360.qq安全助手.安全管家哪个好 安卓系统:安全管家和360哪个好用? 360卫士和腾讯手机管家谁好使用,各的好处有哪些 手机下载的360,,卫士和安全管家有具体作用吗 手机360ID身份令牌 用户名及密码如何获得 手机有个软件名叫手机令牌是不安全吗?360安全卫士是这么说的,我按照它的意思去做,但删除失败,咋办啊 载成语有哪些成语大全 python设计函数,实现会员注册,要求用户名长度不小于3,密码长度不小于6... ...请编写用户注册程序,用户输入用户名和密码,Python程序? 用python编写一个程序,提示用户输入 一个整数,并逐个显示其中的每个数字? 如何构建用户的购买矩阵 python 锂电池能用增程器充电吗? 电动车增程器是否可以直接给电瓶充电? 增程式电车一直充电 增程器能插充电口吗? 锂电池能用增程器充电吗?请问一下锂电池能用发电机充电吗? 电动车电瓶增程器要充电吗 增程式电动车用不用充电? 电池增程包怎么给汽车充电 小刀电动车长征版为什么一次充电能跑300里? 增程式新能源汽车是什么意思? 增程式电动车是什么意思 电动车增程器要不要充电? 合肥哪有买电动车冲电增程器? 增程式怎样连接充电器或再连接电动车插口 电动车增程器车辆不走能充满电瓶吗? 空调外机可以装在比空调位置高吗?