日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python atm作业详解_python day4 作业 ATM

發布時間:2024/9/15 python 47 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python atm作业详解_python day4 作业 ATM 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

作業需求

指定最大透支額度

可取款

定期還款(每月指定日期還款,如15號)

可存款

定期出賬單

支持多用戶登陸,用戶間轉帳

支持多用戶

管理員可添加賬戶、指定用戶額度、凍結用戶等

目錄結構如下:

ATM2/

├── bin

│?? ├── admin_user.py? ##管理員進入界面

│?? ├── atm_user.py? # 普通用戶進入界面

│?? └── __init__.py

├── conf

│?? ├── __init__.py

│?? ├── __pycache__

│?? │?? ├── __init__.cpython-36.pyc

│?? │?? └── settings.cpython-36.pyc

│?? └── settings.py? # 主配置文件 (首先看這個)

├── core

│?? ├── accounts.py? ?# 用戶數據json 文件

│?? ├── auth.py? ? ? ? ?# 用戶認證

│?? ├── bill_date.py? ? # 時間格式

│?? ├── db_handler.py? # 數據庫

│?? ├── __init__.py

│?? ├── logger.py? ? ?#log 文件

│?? ├── main.py? ? ?# 主函數

│?? ├── __pycache__

│?? │?? ├── accounts.cpython-36.pyc

│?? │?? ├── auth.cpython-36.pyc

│?? │?? ├── bill_date.cpython-36.pyc

│?? │?? ├── db_handler.cpython-36.pyc

│?? │?? ├── __init__.cpython-36.pyc

│?? │?? ├── logger.cpython-36.pyc

│?? │?? ├── main.cpython-36.pyc

│?? │?? └── transaction.cpython-36.pyc

│?? └── transaction.py

├── db

│?? ├── accounts

│?? │?? ├── admin.json

│?? │?? ├── liang2.json

│?? │?? └── liang.json

│?? └── __init__.py

├── __init__.py

└── log

├── access.log

├── accounts

├── __init__.py

└── transactions.log

說下心得哈。首先我。我也是第一次寫這種代碼 最開始的時候一個文件相互調來調去的確實繁瑣,

后面看ygqygq2?老哥寫的,豁然開朗。第一步就是看代碼。先把代碼一行行去讀起來。因為我也沒

學多久。久久看了兩天才把老哥的代碼看懂。實在沒辦法。 還有就是看代碼的順序。第一看的是配置

文件,后面你文件頭里面的import 是那個文件,這樣以此類推的看下去。

我的代碼還是有點問題,沒有老哥的代碼寫的完美。那么上代碼把

settings.py

#!/usr/bin/env python#-*- coding:utf-8 -*-#Author: liang

importsys,os,logging

BASE_DIR= os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

sys.path.append(BASE_DIR)

BILL_DAY=25DATABASE={'engine':'file_storage','name':'accounts','path':'%s/db' %BASE_DIR

}

LOG_LEVEL=logging.INFO

LOG_TYPES={'transaction':'transactions.log','access':'access.log',

}

LOG_DATABASE={'engine': 'file_storage','name': 'accounts','path': '%s/log' %BASE_DIR

}

TRANSACTION_TYPE={'repay':{'action':'plus','interest':0}, #還款

'receive':{'action':'plus','interest':0}, #接受

'withdraw':{'action':'munus','interest':0.05}, #提款

'transfer':{'action':'minus','interest':0.05}, #轉出

'pay':{'action':'minus','interest':0}, #支付

'sava':{'action':'plus','interest':0}, #存錢

}

ACCOUNT_FORMAT={'''用戶數據格式

{"enroll_date": "2016-01-02", "password": "abc", "id": 1000, "credit": 15000,

"status": 0, "balance": 1000.0, "expire_date": "2021-01-01", "pay_day": 22}'''}

View Code

db_handler.py

#!/usr/bin/env python#-*- coding:utf-8 -*-#Author: liang

deffile_db_handle(conn_params):'''存放數據的文件路徑

:param conn_params:

:return:'''db_path='%s/%s' %(conn_params['path'],conn_params['name'])returndb_pathdefdb_handler(conn_parms):'''數據庫類型

:param conn_parms:

:return:'''

if conn_parms['engine']=='file_storage':returnfile_db_handle(conn_parms)elif conn_parms['engine']=='mysql':pass

View Code

auth.py

#!/usr/bin/env python#-*- coding:utf-8 -*-#Author: liang

importos,sys

BASE_DIR=os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

sys.path.append(BASE_DIR)importosfrom core importdb_handlerfrom core importaccountsfrom conf importsettingsimportjsonimportdatetimedefacc_auth(account,password):'''用戶驗證函數

:param account:

:param password:

:return:'''db_path=db_handler.db_handler(settings.DATABASE)

account_file="%s/%s.json" %(db_path,account)ifos.path.isfile(account_file):

with open(account_file) as f:

account_data=json.load(f)if account_data["password"] ==password:

exp_time_stamp=datetime.datetime.strptime(account_data['expire_date'], "%Y-%m-%d")

status=account_data['status']if datetime.datetime.now() >exp_time_stamp:print("%s賬戶已近過期了.請聯系管理員"%account)elif status == 0 or status == 8:returnaccount_dataelse:print("賬戶已經過期了。或者不是管理員!!")else:print("密碼錯誤")else:print("文件不存在")defacc_login(user_data,log_obj):'''用戶登錄 的函數

:param user_data:

:param log_obj:

:return:'''exit_count=3 #登錄次數

retry_connt=0 #初始化重試數據

same_account=0 #輸入時。相同數據計數

last_account="" #初始化上一次輸入的用戶

while user_data['is_authenticated'] is not True and retry_connt

account=input("請輸入用戶名:").strip()

password=input("請輸入密碼").strip()if account==last_account:

same_account+=1auth=acc_auth(account,password)

last_account=accountifauth:

user_data['is_authenticated']=True

user_data['account_id']=accountreturnauth

retry_connt+=1

else:if same_account==exit_count -1:

log_obj.error("account [%s] too many login attempts" %account)

exit()defacc_check(account):'''查詢賬戶是否存在

:param account:

:return:'''db_path=db_handler.db_handler(settings.DATABASE)

account_file="%s/%s.json" %(db_path,account)ifos.path.isfile(account_file):

with open(account_file,'r') as f:

account_data=json.load(f)

status=account_data["status"]

exp_time_stamp=datetime.datetime.strptime(account_data['expire_date'],"%Y-%m-%d")if datetime.datetime.now()>exp_time_stamp:print("此%s賬戶已經過期。請聯系管理員"%account)else:returnaccount_dataelse:returnFalsedefsign_up():'''用戶注冊和admin 管理員用戶

:return:'''pay_dat=22exit_flag=Truewhile exit_flag isTrue:

account=input("請輸入你的用戶名:").strip()

password=input("請輸入你的密碼:").strip()

exit_flag=acc_check(account)ifexit_flag:print("次用戶已經存在。請選擇其他用戶名")else:#現在的時間格式

today=datetime.datetime.now().strftime("%Y-%m-%d")#默認五年后過期

after_5_years=int(datetime.datetime.now().strftime('%Y')) +5

#五年后的今天

after_5_years_today=datetime.datetime.now().replace(year=after_5_years)#五年后的昨天

expire_day=(after_5_years_today + datetime.timedelta(-1)).strftime('%Y-%m-%d')"""用戶數據庫格式

{"enroll_date": "2016-01-02", "password": "abc", "id": 1000, "credit": 15000,"balance":0,

"status": 0, "balance": 1000.0, "expire_date": "2021-01-01", "pay_day": 22}"""account_data={"enroll_date":today,"password":password,"id":account,"credit":15000,"balance":0,"status":0,"expire_date":expire_day,"pay_day":pay_dat}print(account_data)

accounts.dump_account(account_data)print("添加成功 用戶ID:[%s]!!!" %account)returnTruedefmodify():'''修改用戶信息

:return:'''items=["password","credit","status","expire_day","pay_day"]

acc_data=False

contine_flag=Falsewhile acc_data isFalse:

account=input("請輸入你要修改的用戶名:").strip()#丟到驗證函數中

account_data=acc_check(account)if account_data isFalse:print("你輸入的用戶不存在")else:while contine_flag is notTrue:#判斷輸入json 格式

print('''請你輸入json 格式

{

"password": "abc",

"credit": 15000,

"status": 0,

"expire_date": "2021-01-01",

"pay_day": 22

}''')

modify_items=input("請你輸入json格式").strip()try:

modify_items=json.loads(modify_items)exceptException as e:print("輸入錯誤!!!")continueerror_flag=False #初始化錯誤標記

for index inmodify_items:if index initems:#修改用戶數據 就是字典修改方式

account_data[index]=modify_items[index]else:print("輸入有錯誤!!!")continue

iferror_flag:continue

#再寫到文件中

accounts.dump_account(account_data)print("修改成功!!!")

contine_flag=True

acc_data=Truereturn True

View Code

accounts.py

#!/usr/bin/env python#-*- coding:utf-8 -*-#Author: liang

importjsonimporttimefrom core importdb_handlerfrom conf importsettingsdefload_current_balance(account_id):'''json load 用戶文件

:param account_id:

:return:'''db_path=db_handler.db_handler(settings.DATABASE)#db_path 調用的是配置文件的DATABASE路徑

#db_path 完整的路徑是 ATM\db\accounts

account_file="%s/%s.json" %(db_path,account_id)

with open(account_file,'r') as f:

acc_data=json.load(f)returnacc_datadefdump_account(account_data):'''寫到文件當中

:param account_data:

:return:'''db_path=db_handler.db_handler(settings.DATABASE)#這個數據的目錄 ATM\db\accounts

account_file="%s/%s.json" %(db_path,account_data['id'])

with open(account_file,'w') as f:

acc_data=json.dump(account_data,f)return True

View Code

bill_date.py

#!/usr/bin/env python#-*- coding:utf-8 -*-#Author: liang

from conf importsettingsimportdatetimedefget_bill_time(year_month):'''獲取給出的年-月的信用卡賬單 月份起止時間

:param year_month: 年-月

:return: 返回時間'''the_bill_day="%s-%s" %(year_month,settings.BILL_DAY)

bill_begin_time=datetime.datetime.strptime(the_bill_day,"%Y-%m-%d")

year=bill_begin_time.year

month=bill_begin_time.monthif month ==12:

month=1year+=1

else:

month+=1bill_end_time=datetime.datetime(year,month,settings.BILL_DAY)return bill_begin_time,bill_end_time

View Code

transaction.py

#!/usr/bin/env python#-*- coding:utf-8 -*-#Author: liang#

from conf importsettingsfrom core importaccountsfrom core importlogger#transaction logger

def make_transaction(log_obj, account_data, tran_type, amount, **others):'''deal all the user transactions

:param account_data: user account data

:param tran_type: transaction type

:param amount: transaction amount

:param others: mainly for logging usage

:return:'''

#交易金額 為浮點型

amount =float(amount)#判斷交易類型是否在存在里面

if tran_type insettings.TRANSACTION_TYPE:#利息的計算

interest = amount * settings.TRANSACTION_TYPE[tran_type]['interest']#我現有的金額

old_balance = account_data['balance']#判斷是否是加金額

if settings.TRANSACTION_TYPE[tran_type]['action'] == 'plus':#金額的加 是 本金+交易金額+ 利息

new_balance = old_balance + amount +interest#如果為減

elif settings.TRANSACTION_TYPE[tran_type]['action'] == 'minus':#那就是 本金 減 交易金額 減 利息

new_balance = old_balance - amount -interest#check credit

#減去了 所有的 如果大于0

if new_balance <0:#輸出用戶的額度 、 減少了多少金額 、剩下了多少額度

print('''Your credit [\033[31;1m%s\033[0m] is not enough for this transaction [-%s],

your current balance is [\033[32;1m%s\033[0m]'''

% (account_data['credit'], (amount +interest), old_balance))return

#把用戶剩余的額度 寫入到文件中

account_data['balance'] =new_balance#json 序列化到文件中

accounts.dump_account(account_data) #save the new balance back to file

#輸出用戶的用戶名、交易類型、交易金額、利息

log_obj.info("account:%s action:%s amount:%s interest:%s" %(account_data['id'], tran_type, amount, interest))#返回最新的用戶數據

returnaccount_data#不存在的交易類型

else:print("\033[31;1mTransaction type [%s] is not exist!\033[0m" %tran_type)#from conf import settings#from core import accounts#from core import logger#

#

#

#

#

#def make_transaction(log_obj,account_data,tran_type,amount,**kwargs):#'''#交易函數#:param log_obj: log#:param account_data: 用戶數據#:param tran_type: 交易類型#:param amount: 金額action#:param kwargs: 主要用于日志#:return:#'''##交易金額 為浮點型#amount=float(amount)#

#if tran_type in settings.TRANSACTION_TYPE:#

##利息的計算#interest=amount *settings.TRANSACTION_TYPE[tran_type]['interest']#print(interest)## 現有的余額#old_balance= account_data['balance']#

##判斷是否加金額#if settings.TRANSACTION_TYPE[tran_type]['action'] == 'plus':## 金額 就是本金+交易金額+利息#new_balance=old_balance+amount+interest#print(new_balance)##如果是減去#elif settings.TRANSACTION_TYPE[tran_type]['action']=='minus':#new_balance=old_balance-amount-interest#if new_balance<0:#print("你的額度為%s .你本次交易的金額(+利息的)%s 你的余額為%s"%(account_data['credit'],(amount+interest),account_data['old_balance']))#return None##把用戶更新的額度寫入到文件中#account_data['balance']= new_balance#

## json 序列化到文件中#xx=accounts.dump_account(account_data)## 輸出用戶的用戶名、交易類型、交易金額、利息#log_obj.info("account:%s action:%s amount:%s interest:%s" %#(account_data["id"],tran_type,amount,interest))#

#return xx#

#else:#print("錯誤類型")## money=input("輸入需要存款的數量:>>>")## account_data={'enroll_date': '2018-01-31', 'password': '123456', 'id': 'liang', 'credit': 15000, 'balance': 0, 'status': 0, 'expire_date': '2023-01-30', 'pay_day': 22}#### x=make_transaction(trans_logger,account_data,'sava',money)## print(x)

View Code

logger.py

#!/usr/bin/env python#-*- coding:utf-8 -*-#Author: liang

importloggingimportdatetimefrom conf importsettingsfrom core importbill_datedeflogger(log_type):#創建loggin

logger =logging.getLogger(log_type)

logger.setLevel(settings.LOG_LEVEL)#create console handler and set level to debug

ch =logging.StreamHandler()

ch.setLevel(settings.LOG_LEVEL)#create file handler and set level to warning

#創建 log 文件的一個級別

log_file = "%s/log/%s" %(settings.BASE_DIR, settings.LOG_TYPES[log_type])

fh=logging.FileHandler(log_file)

fh.setLevel(settings.LOG_LEVEL)#create formatter

#log的輸入格式

formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')#add formatter to ch and fh

ch.setFormatter(formatter)

fh.setFormatter(formatter)#add ch and fh to logger

logger.addHandler(ch)

logger.addHandler(fh)returnlogger#'application' code

'''logger.debug('debug message')

logger.info('info message')

logger.warn('warn message')

logger.error('error message')

logger.critical('critical message')'''

defshow_log(account, log_type, year_month):"""顯示日志內容

:param user_name: 用戶名

:param log_type: 日志類型

:return:"""

#給出的賬單時間 結束的賬單時間

begin_time, end_time =bill_date.get_bill_time(year_month)#log文件的所在路徑

log_file = "%s/log/%s" %(settings.BASE_DIR, settings.LOG_TYPES[log_type])#打開log文件

file =open(log_file)print("-".center(50, "-"))for line infile:#log 時間

log_time = datetime.datetime.strptime(line.split(",")[0], "%Y-%m-%d %H:%M:%S")#記錄的用戶

user_name = line.split()[7].split(":")[1]#帳單生成日是25號,則每月帳單是從上月25日到本月24日之間

if account == user_name and begin_time <= log_time

file.close()#import os,sys#BASE_DIR=os.path.dirname(os.path.dirname(os.path.abspath(__file__)))#sys.path.append(BASE_DIR)#import logging#import datetime#from conf import settings#from core import bill_date#

#

#def logger(log_type):#

##創建loggin#logger=logging.getLogger(log_type)#logger.setLevel(settings.LOG_LEVEL)#

#ch=logging.StreamHandler()#ch.setLevel(settings.LOG_LEVEL)#

## 創建log 文件 級別#log_file="%s/log/%s" %(settings.BASE_DIR,settings.LOG_TYPES[log_type])#fh =logging.StreamHandler(log_file)#fh.setLevel(settings.LOG_LEVEL)#

##log 的輸入格式#formatter=logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')#

#ch.setFormatter(formatter)#fh.setFormatter(formatter)#

#return logger#

#def show_log(account,log_type,year_month):#'''#顯示 日志內容#:param account: 用戶 名#:param log_type: 日志類型#:param year_month:#:return:#'''## 給出賬單 時間 結束時間#begin_time,end_time=bill_date.get_bill_time(year_month)## log 文件路徑#log_file="%s/log/%s" %(settings.BASE_DIR,settings.LOG_TYPES[log_type])#

## 打開log文件#file=open(log_file,'r')#print("-".center(50,"-"))#for line in file:## log 時間#log_time=datetime.datetime.strptime(line.split(",")[0],"%Y-%m-%d %H:%M:%S")## 記錄用戶#user_name=line.split()[7].split(":")[1]##賬單生成日是25 號 則每月賬單是從上月25到本月24之間#if account==user_name and begin_time<=log_time

#

#

#

#x=logger('transaction')#x.info("account:%s action:%s amount:%s interest:%s" %('liang','tran_type','amount','interest'))

View Code

main.py

#!/usr/bin/env python#-*- coding:utf-8 -*-#Author: liang

importos,sys

BASE_DIR=os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

sys.path.append(BASE_DIR)from core importauthfrom core importloggerfrom core importaccountsfrom core importtransactionfrom core importdb_handlerfrom conf importsettingsimportdatetimeimporttimeimportos#建立transaction.log 文件

trans_logger=logger.logger('transaction')#建立 access.log 文件

access_logger=logger.logger('access')#臨時賬戶數據、僅保存在內存中

user_data={'account_id':None,'is_authenticated':False,'account_data':None

}defdisp_account_info(account_data):'''格式化輸出賬戶信息(管理員可直接使用)

#去除 password 字段顯示

:param account_data: 賬戶信息

:return:'''ignore_display=["password"]for k inaccount_data:if k inignore_display:continue

else:print("{:<20}:\033[32;1m{:<20}\033[0m".format(k, account_data[k]))defadmin_account_info(acc_data):'''管理員查看其它用戶

:param acc_data:

:return:'''user_id=acc_data["account_id"]

account_data=acc_data["account_data"]

status=account_data["status"]if status ==8:

admin_input_id=input("請輸入你需要查詢的ID").strip()

new_user_info=auth.acc_check(admin_input_id)

new_user_status=new_user_info["status"]if new_user_status ==8:if user_id==admin_input_id:

disp_account_info(new_user_info)returnTrueelse:print("你能查詢其它管理員【%s】的信息"%(admin_input_id))elif new_user_info !=8:

disp_account_info(new_user_info)else:

exit("非法操作")defaccount_info(acc_data):'''普通用戶打印登錄用戶信息

:param acc_data: 登錄信息

:return:'''

#用戶ID

account_id=acc_data["account_id"]# account_data=acc_data["account_data"]# status=account_data["status"]# if status !=8:

disp_account_info(account_data)returnTrueelse:

exit("謝謝!!!!!")defget_user_data():'''登錄并獲取新的user-data

:return:'''account_data=auth.acc_login(user_data,access_logger)if user_data["is_authenticated"]:#此刻就是有數據了

user_data["account_data"]=account_data#返回最新用戶數據

returnuser_dataelse:returnNonedefpay(amount):'''消費付款

:param amount: 付款金額

:return:'''

#用戶數據

acc_data=get_user_data()

account_data=accounts.load_current_balance(acc_data['account_id'])if amount>0:#new_balance 是用戶的最新數據。有兩個結果 。一個是None 一個是用戶數據

new_balance=transaction.make_transaction(trans_logger,account_data,'pay',amount)ifnew_balance:returnTrue#小于0

else:print("你輸入的金額需要大于0%s"%amount)returnNonedefrepay(acc_data):'''還款

:param acc_data:

:return:'''

print(acc_data)

account_data= accounts.load_current_balance(acc_data['account_id'])

current_blance='''-------- balance info ---------

Credit : %s

Balance: %s'''%(account_data['credit'],account_data['balance'])print(current_blance)

back_flag=Falsewhile notback_flag:print("按b退出")#還款金額

reap_amount=input("請輸入你還款的金額:>>").strip()if len(reap_amount) >0 andreap_amount.isdigit():#new_balance = 用戶最新數據

new_balance=transaction.make_transaction(trans_logger,account_data,'repay',reap_amount)

time.sleep(0.1)ifnew_balance:print("你的余額為%s"%(new_balance['balance']))elif reap_amount =='b':

back_flag=Trueelse:print("輸入錯誤。請從新輸入!!!!%s"%(reap_amount))defwithdraw2(acc_data):'''提款

:param acc_data:

:return:'''

#用戶最新數據

account_data=accounts.load_current_balance(acc_data['account_id'])

current_blance='''-------- balance info ---------

Credit : %s

Balance: %s'''%(account_data['credit'],account_data['balance'])print(current_blance)

back_flag=Falsewhile notback_flag:print("輸入b 跳出")

withdrwa_amount=input("請輸入提款金額:>>>").strip()if len(withdrwa_amount)>0 andwithdrwa_amount.isdigit():

new_balance2=transaction.make_transaction(transaction,account_data,'withdraw',withdrwa_amount)

time.sleep(0.1)ifnew_balance2:print("你剩余的余額%s" %new_balance2['balance'])elif withdrwa_amount=='b':

back_flag=Trueelse:print("你輸入錯誤!!!%s"%withdrwa_amount)defwithdraw(acc_data):'''提款

print current balance and let user do the withdraw action

:param acc_data:

:return:'''

#用戶最新數據

account_data = accounts.load_current_balance(acc_data['account_id'])#格式化輸出用戶的 額度+ 用戶的賬目

current_balance = '''--------- BALANCE INFO --------

Credit : %s

Balance: %s''' % (account_data['credit'], account_data['balance'])print(current_balance)

back_flag=Falsewhile notback_flag:print("Tip: [b] to back")#輸入還款金額

withdraw_amount = input("\033[33;1mInput withdraw amount:\033[0m").strip()#長度大于0 并且是數字

if len(withdraw_amount) > 0 andwithdraw_amount.isdigit():#返回用戶最新的數據

new_balance = transaction.make_transaction(trans_logger, account_data, 'withdraw', withdraw_amount)

time.sleep(0.1) #處理顯示問題

#如果有數據, 就顯示現有的賬目

ifnew_balance:print('''\033[42;1mNew Balance:%s\033[0m''' % (new_balance['balance']))elif withdraw_amount == 'b':

back_flag=Trueelif withdraw_amount == 'q' and withdraw_amount == 'exit':

exit("謝謝下次再來")break

else:print('[\033[31;1m%s\033[0m] is not a valid amount, only accept integer!' %withdraw_amount)deftransfer(acc_data):'''打印出當前余額 并轉錢

:param acc_data:

:return:'''

#用戶最近數據

account_data=accounts.load_current_balance(acc_data['account_id'])#顯示用戶的額度

current_blance='''-------- balance info ---------

Credit : %s

Balance: %s'''%(account_data['credit'],account_data['balance'])print(current_blance)

back_flag=Falsewhile notback_flag:#輸入轉給誰 .不能轉給自己

recevier=input("輸入你需要轉錢的用戶:>>>>").strip()if str(recevier)==str(account_data["id"]):print("不能轉給自己")continue

elif recevier=='b':

back_flag=Trueelse:#檢查是否有這個ID

receiver_account_data=auth.acc_check(recevier)#判斷這個Id 是否過期和是不是普通用戶

status=receiver_account_data["status"]print(status)if status ==0:#如果等于0就讓他輸入金額

transfer_amount=input("輸入你需要轉的金額:>>")if len(transfer_amount) >0 andtransfer_amount.isdigit():

new_blance=transaction.make_transaction(trans_logger,account_data,'transfer',transfer_amount)

transaction.make_transaction(trans_logger,receiver_account_data,'receive',transfer_amount)ifnew_blance:

time.sleep(0.2)print("轉錢成功!!!")else:print("請輸入大于0的金額!!!!")if transfer_amount=='b':

back_flag=Trueelse:print("不能轉為其他人")defpay_check(acc_data):'''查詢賬單詳情

:param acc_data:

:return:'''bill_data=input("請輸入你需要查詢的年月份 例如[2018-01]:>>>>").strip()

log_path=db_handler.db_handler(settings.DATABASE)

bill_log="%s/%s.bills" %(log_path,acc_data["account_id"])if notos.path.exists(bill_log):print("沒有記錄用戶[%s]"%acc_data["account_id"])return

print("請輸入你需要查詢的ID %s"%acc_data["account_id"])print("-".center(50,'#'))

with open(bill_data,'r') as f:for bill inf:print(bill)

b_data=bill.split(" ")[0]if bill_data==b_data:print("%s"%bill.strip())

log_type="transactions"

print("%s" %acc_data["account_id"])

logger.show_log(acc_data["account_id"],log_type,bill_data)defsave(acc_data):'''存錢

:param acc_data:

:return:'''account_data=accounts.load_current_balance(acc_data["account_id"])print(account_data)

current_balance= '''--------- BALANCE INFO --------

Credit : %s

Balance: %s

(Tip: input [b] to back)''' % (account_data['credit'], account_data['balance'])print(current_balance)

back_flag=Falsewhile notback_flag:#輸入存款金額

save_amount=input("輸入你需要存款的金額:>>>").strip()if save_amount == 'b':

back_flag=Trueelif len(save_amount) > 0 andsave_amount.isdigit():

new_balance= transaction.make_transaction(trans_logger, account_data, 'save', save_amount)

time.sleep(0.1) #解決日志顯示問題

ifnew_balance:print('''\033[42;1mNew Balance:%s\033[0m''' % (new_balance['balance']))

back_flag=Trueelse:print('[\033[31;1m%s\033[0m] is not a valid amount, only accept integer!' %save_amount)deflogout(acc_data):'''清除認證信息、退出

:param acc_data:

:return:'''exit("謝謝!!!!".center(50,'#'))definteractive(acc_data):'''普通用戶界面

:param acc_data:

:return:'''status=acc_data["account_data"]["status"]if status==8:print("管理員不能查看!!%s"%acc_data["account_id"])

menu=u'''----------- user bank ------------

1. 賬戶信息

2. 還款

3. 取款

4. 轉賬

5. 存款

6. 賬單

7. 退出'''menu_dic={'1':account_info,'2':repay,'3':withdraw,'4':transfer,'5':save,'6':pay_check,'7':logout,

}

exit_flag=Falsewhile notexit_flag:print(menu)

user_option=input(":>>>").strip()if user_option inmenu_dic:#print(acc_data)

menu_dic[user_option](acc_data)else:print("輸入錯誤!!!")defget_bill(account_id):'''生成賬單 、定義每月25 日

:param account_id:

:return:'''

#當前時間

i =datetime.datetime.now()

year_month="%s-%s" %(i.year,i.month)

account_data=accounts.load_current_balance(account_id)

balance=account_data["balance"]#可用額度

credit=account_data["credit"]if i.day !=settings.BILL_DAY:print("\033[31;1mToday is not the bill generation day!\033[0m")if balance>=credit:

repay_amount=0

bill_info="Account [\033[32;1m%s\033[0m] needn't to repay." %account_idelse:

repay_amount=credit-balance

bill_info="Account [\033[32;1m%s\033[0m] need to repay [\033[33;1m%s\033[0m]"\%(account_id, repay_amount)print(bill_info)

log_path=db_handler.db_handler(settings.LOG_DATABASE)

bill_log="%s/%s.bills" %(log_path,account_data["account_id"])

with open(bill_log,'a+') as f:

f.write("bill_date: %s account_id: %s need_repay: %d\n" %(year_month, account_id, repay_amount))defget_all_bill():

db_path=db_handler.db_handler(settings.DATABASE)for root, dirs , files inos.walk(db_path):for file infiles:#分割出來結尾的文件

if os.path.splitext(file)[1] =='json':

account_id=os.path.splitext(file)[0] #賬戶id

#檢查這個賬戶

account_data=auth.acc_check(account_id)

status=account_data['status']print("Account bill:".center(50,'='))#除了管理員其他人都應該出賬單

if status !=8:

disp_account_info(account_data)#顯示賬戶詳情

get_bill(account_id)print("End".center(50,'-'))returnTruedefchenk_admin(func):'''檢查是否是管理員

:param func:

:return:'''

def inner(*args,**kwargs):if user_data['account_data'].get('status',None)==8:

ret=func(*args,**kwargs)returnretelse:print("不是管理員")returninnerdefmanage_func(acc_data):'''管理員功能

:param acc_data:

:return:'''menu= u'''------- Admin erea ---------\033[32;1m

1. 添加賬戶

2. 查詢用戶信息

3. 用戶信息修改(凍結帳戶、用戶信用卡額度等)

4. 生成全部用戶帳單

5. 退出

\033[0m'''menu_dic={'1':'auth.sign_up()','2':'account_info(acc_data)','3':'auth.modify()','4':'get_all_bill()','5':'logout(acc_data)',

}

go_flag=Truewhilego_flag:print(menu)

user_option=input(":>>").strip()if user_option inmenu_dic.keys():

go_flag=eval(menu_dic[user_option])else:print("\033[31;1mOption does not exist!\033[0m")defrun():'''這個是普通用戶運行的界面

:return:'''

print("Welocome to ATM".center(50,'#'))

user_data=get_user_data()

interactive(user_data)defadmin_run():print("ATM admin manager".center(50,'#'))

user_data=get_user_data()

manage_func(user_data)

View Code

admin_user.py

#!/usr/bin/env python#-*- coding:utf-8 -*-#Author: liang

importosimportsys

base_dir= os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

sys.path.append(base_dir)from core importmainif __name__ == '__main__':

main.admin_run()#管理員賬戶 admin 密碼 abc

View Code

atm_user.py

#!/usr/bin/env python#-*- coding:utf-8 -*-#Author: liang

importosimportsys

base_dir= os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

sys.path.append(base_dir)from core importmainif __name__ == '__main__':

main.run()#普通用戶 liang 密碼 123456

View Code

文件的存儲位置如以下圖片:

測試如下:

C:\Users\Administrator\AppData\Local\Programs\Python\Python36\python36.exe G:/python/ATM2/bin/atm_user.py

#################Welocome to ATM #################

請輸入用戶名:liang

請輸入密碼123456

----------- user bank ------------

1. 賬戶信息

2. 還款

3. 取款

4. 轉賬

5. 存款

6. 賬單

7. 退出

:>>>1

enroll_date :2018-01-31

id :liang

credit :15000

balance :1888888888737010.2

status :0

expire_date :2023-01-30

pay_day :22

----------- user bank ------------

1. 賬戶信息

2. 還款

3. 取款

4. 轉賬

5. 存款

6. 賬單

7. 退出

:>>>2

{'account_id': 'liang', 'is_authenticated': True, 'account_data': {'enroll_date': '2018-01-31', 'password': '123456', 'id': 'liang', 'credit': 15000, 'balance': 1888888888737010.2, 'status': 0, 'expire_date': '2023-01-30', 'pay_day': 22}}

-------- balance info ---------

Credit : 15000

Balance: 1888888888737010.2

按b退出

請輸入你還款的金額:>>10

2018-01-31 15:41:35,310 - transaction - INFO - account:liang action:repay amount:10.0 interest:0.0

你的余額為1888888888737020.2

按b退出

請輸入你還款的金額:>>b

----------- user bank ------------

1. 賬戶信息

2. 還款

3. 取款

4. 轉賬

5. 存款

6. 賬單

7. 退出

:>>>4

-------- balance info ---------

Credit : 15000

Balance: 1888888888737020.2

輸入你需要轉錢的用戶:>>>>admin

8

不能轉為其他人

輸入你需要轉錢的用戶:>>>>liang

不能轉給自己

輸入你需要轉錢的用戶:>>>>liang2

0

輸入你需要轉的金額:>>1000

2018-01-31 15:42:21,639 - transaction - INFO - account:liang action:transfer amount:1000.0 interest:50.0

2018-01-31 15:42:21,639 - transaction - INFO - account:liang2 action:receive amount:1000.0 interest:0.0

轉錢成功!!!

輸入你需要轉錢的用戶:>>>>

總結

以上是生活随笔為你收集整理的python atm作业详解_python day4 作业 ATM的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

日韩色区 | 久久精品5| 国产精品欧美日韩 | 久久九九影视网 | 欧美 日韩精品 | 激情综合色综合久久综合 | 超碰在线人人爱 | 中文字幕久久亚洲 | 丁香综合 | 中文字幕在线播放日韩 | 中文字幕免费高 | 日本公乱妇视频 | 国产黄在线播放 | 亚洲精品国精品久久99热一 | 成人黄色在线视频 | 中文字幕在线看视频国产 | 国产美女在线免费观看 | 日日夜夜天天综合 | 麻豆影视在线播放 | 成人久久精品视频 | 最近中文字幕大全 | 国产麻豆精品一区二区 | 欧美尹人| 91在线www| 麻豆传媒视频观看 | 色资源二区在线视频 | 在线观看免费国产小视频 | 亚洲第一区精品 | 国产精品福利在线 | 97电影在线看视频 | 一级黄色大片 | 国产成人在线网站 | 国产资源网 | 热99久久精品 | 视频二区在线 | 2019中文最近的2019中文在线 | 国产成人综合在线观看 | 五月婷婷丁香综合 | 亚洲毛片视频 | 女人18精品一区二区三区 | 视频直播国产精品 | 五月婷婷网站 | 超碰97国产精品人人cao | 麻豆手机在线 | 久久精品123 | 国产午夜精品福利视频 | а天堂中文最新一区二区三区 | 狠狠久久综合 | 色狠狠操 | 日操操 | 亚洲性xxxx| 91精品第一页 | 色婷婷av一区二 | 日韩综合一区二区三区 | 久久精品在线视频 | 美女性爽视频国产免费app | 亚洲日本va中文字幕 | 亚洲欧美在线综合 | 国产视频中文字幕在线观看 | 在线免费观看羞羞视频 | 色91在线视频 | 欧美综合在线视频 | 国产四虎在线 | 天天综合婷婷 | 日韩va欧美va亚洲va久久 | 国产精品一区二区三区在线看 | 国产成人资源 | 国产做爰视频 | 99亚洲天堂| 天天摸夜夜添 | 日本韩国精品一区二区在线观看 | 欧美视屏一区二区 | 日韩精品一区二区在线观看 | 国产精品永久久久久久久www | 国产在线精品一区二区 | 天天操夜夜拍 | 精品免费久久久久 | 亚洲v欧美v国产v在线观看 | 国产黄色播放 | 99久久精品国产一区二区成人 | 99久久精品国产免费看不卡 | 狠狠色丁香婷婷综合久久片 | 伊人久久一区 | 久久精品99久久久久久2456 | 激情av一区二区 | a在线观看免费视频 | 日批视频| 婷婷国产精品 | 精品国产一区二区三区久久久 | 99在线观看视频 | 日韩一区二区三区不卡 | 日韩精品一区二区三区免费观看 | av性网站 | 国内精品在线看 | 中文字幕在线乱 | 国产网站在线免费观看 | 久久精品视频2 | 国产在线1区 | 成人黄性视频 | 不卡的av中文字幕 | 中国精品一区二区 | 国产精品中文在线 | 欧美日韩免费在线观看视频 | 天无日天天操天天干 | 五月天婷婷在线播放 | 99久久er热在这里只有精品15 | 免费观看黄 | 99精品国产aⅴ | 欧美日韩在线播放一区 | 国内精品视频在线播放 | 在线观看免费高清视频大全追剧 | 中文字幕在线影视资源 | 中文区中文字幕免费看 | 亚洲综合在线视频 | 中文字幕91视频 | 久久久久婷 | 国产精品扒开做爽爽的视频 | 国产精品theporn | 91亚瑟视频 | 六月激情婷婷 | 国产va饥渴难耐女保洁员在线观看 | 在线观看 国产 | 久久黄页 | 在线观看av不卡 | 久久精品免费 | 免费看片网址 | 伊人五月| 黄色99视频 | 国产一区二区三区免费视频 | 久久精品三 | 欧美色图另类 | 国产精品 日韩精品 | 久久这里只有精品9 | 91毛片在线观看 | 超碰大片 | 一区二区三区四区久久 | 国产精久久 | 天堂在线一区二区 | 夜夜操综合网 | 日韩激情在线 | 黄色视屏在线免费观看 | 久草影视在线观看 | 中文字幕av一区二区三区四区 | 狠狠操狠狠 | 人人看人人草 | 中文字幕av在线电影 | 人人澡人人澡人人 | 国产中文伊人 | 99精彩视频| 国内精品免费久久影院 | 成人免费观看视频大全 | 国产男女免费完整视频 | 国产精品久久久久久久久久不蜜月 | 中文一区二区三区在线观看 | 精品黄色在线 | 日韩欧美视频一区二区三区 | 在线观看一 | 最新极品jizzhd欧美 | 国产精品美女久久久久久久 | 狠狠干狠狠色 | 五月天网页 | 黄色成人免费电影 | 亚洲国产午夜视频 | 国产一线二线三线在线观看 | 中文一区在线 | 日韩av一区二区三区在线观看 | www.99av| 麻豆视频在线免费 | 国产亚洲精品v | 国产精品99久久久久久人免费 | 久久精品一二三区 | 黄色在线网站噜噜噜 | 天天插天天爱 | 国产免费亚洲 | 国产精品一级在线 | 久草在线在线 | av成人动漫 | 欧美激情另类 | 亚洲免费精品一区二区 | 久久精品4 | 麻豆成人精品视频 | 国产午夜精品久久 | 国产精品久久久久婷婷二区次 | 精品久久国产精品 | 亚洲专区在线播放 | 玖玖爱国产在线 | 91亚洲精品久久久蜜桃借种 | 亚洲综合视频网 | 久久99久久久久久 | 国产黄色片久久久 | 色在线视频 | 国产精品男女视频 | 日韩黄视频 | 91大神dom调教在线观看 | 91精品国产一区二区在线观看 | 成人性生交大片免费看中文网站 | 亚洲精品合集 | а天堂中文最新一区二区三区 | 99中文字幕 | 午夜精品久久久久久久99 | 欧美另类69 | 天天色官网 | 日韩午夜电影院 | 日日夜夜噜| 国产在线观看你懂的 | 日躁夜躁狠狠躁2001 | 国产123av| 91热在线| 中文字幕视频网 | 一区二区三区在线免费 | 国产一区二区视频在线播放 | 国产一区欧美日韩 | 成人av免费在线 | 在线视频18在线视频4k | 久久撸在线视频 | 久久精品视频一 | 五月婷婷久| 91色吧 | 久久tv视频 | 久久这里只精品 | 国产精品久久久久久久久久久久久久 | 天堂资源在线观看视频 | 色播六月天 | 91精品福利在线 | 最新日韩中文字幕 | 亚洲午夜精品福利 | 天天爱天天爽 | 精品美女国产在线 | www.色午夜 | 久久精品免费 | 国产一区二区在线视频观看 | 国产艹b视频 | 久99久精品| 97精品超碰一区二区三区 | 在线免费中文字幕 | 99精品视频在线观看视频 | 久久婷婷网 | 黄色亚洲大片免费在线观看 | 91精品爽啪蜜夜国产在线播放 | 国内毛片毛片 | 毛片网站观看 | 国产又粗又硬又爽视频 | 日韩午夜小视频 | 久久激五月天综合精品 | 国产97在线视频 | 亚洲 欧美 日韩 综合 | 免费a v视频 | 在线天堂8√ | 日韩二三区 | 精品国产一区二区三区蜜臀 | 欧美成人基地 | 亚洲第一av在线 | 国产青草视频在线观看 | 久久大片| 夜夜干天天操 | 日本中文字幕在线免费观看 | 99爱这里只有精品 | 午夜久久精品 | 天天操夜夜逼 | 热久久视久久精品18亚洲精品 | 美女久久99 | 91在线麻豆 | 一区二区欧美激情 | 国产免费一区二区三区网站免费 | 亚洲天堂在线观看完整版 | 精品国产三级a∨在线欧美 免费一级片在线观看 | 免费看一级特黄a大片 | 综合色站导航 | 国产成人av在线 | 久久女教师 | 天天干com | 日本久久久影视 | 国产特级毛片aaaaaa毛片 | 久久久精品国产一区二区 | 粉嫩一二三区 | 久久福利综合 | 99久久久久国产精品免费 | 成片人卡1卡2卡3手机免费看 | 新av在线| 精品v亚洲v欧美v高清v | 国产亚洲情侣一区二区无 | 91成人免费观看视频 | 欧美性久久久 | 天天做天天爱天天爽综合网 | 日本久久久久久 | 麻豆视频在线观看免费 | 国产精品涩涩屋www在线观看 | 在线 高清 中文字幕 | 国产另类av | 激情五月婷婷激情 | 亚洲伊人第一页 | 国产无套一区二区三区久久 | 久操伊人 | 在线亚洲欧美视频 | 精品欧美小视频在线观看 | 国产专区视频在线观看 | 久久久久久久精 | 免费看的av片 | 精品美女在线观看 | 国产亚洲在线观看 | 日韩女同av | 五月婷婷网站 | 中文字幕日韩一区二区三区不卡 | 日韩综合第一页 | 亚洲精品免费观看 | 黄色网在线免费观看 | 激情婷婷网 | 中文国产成人精品久久一 | 99性视频| 婷婷综合网 | 尤物一区二区三区 | 97理论片 | 天天性天天草 | 国产不卡在线视频 | 日韩在线第一 | 欧美国产日韩一区二区 | 国产又粗又猛又爽又黄的视频先 | 中文字幕国语官网在线视频 | 国产一区在线免费 | 大片网站久久 | 色爱区综合激月婷婷 | 黄色毛片网站在线观看 | 日韩精品视频免费在线观看 | 婷婷色综合 | 国产精品美女久久久久久久久久久 | 中文字幕制服丝袜av久久 | 国产精品网址在线观看 | 最新久久久 | 一区久久久 | 国产黄a三级三级 | 在线观看精品视频 | 日韩毛片在线免费观看 | 高清av中文字幕 | 欧美日韩在线视频免费 | 免费中文字幕在线观看 | 在线观看岛国av | 六月激情婷婷 | 欧美日韩1区 | 美女国产在线 | www.伊人网 | 国内综合精品午夜久久资源 | 深夜男人影院 | 免费在线色视频 | 高清国产午夜精品久久久久久 | 久 久久影院| 欧美伦理一区二区 | 亚洲视频中文 | 日韩精品在线一区 | 99re热精品视频 | 久久精品网站免费观看 | 国内精品久久久久久久影视麻豆 | 亚洲国产精彩中文乱码av | 免费观看性生交 | 99在线观看视频 | 成人国产综合 | 日韩免费电影一区二区三区 | 成人免费在线观看电影 | 黄色小说视频网站 | 国产一区二区日本 | 色av男人的天堂免费在线 | 免费情趣视频 | 九九热99视频 | 在线观看午夜 | 久久精品亚洲精品国产欧美 | 波多野结衣电影一区二区三区 | 美女在线免费视频 | 日韩二区三区在线观看 | 日韩精品在线看 | 偷拍福利视频一区二区三区 | 午夜国产福利视频 | 久久婷婷一区二区三区 | 成人在线观看日韩 | 婷婷丁香激情网 | 国产亚洲精品精品精品 | 精品一区二区三区四区在线 | 免费色视频 | 国产人成在线视频 | 狠狠操影视| 在线观看 国产 | 成片免费观看视频999 | 成人国产网站 | 波多野结衣动态图 | 亚洲精品tv久久久久久久久久 | 97国产情侣爱久久免费观看 | 国内精品美女在线观看 | 久久久久久久久久网站 | 国产一级淫片在线观看 | 国色天香在线观看 | av网站免费在线 | 视频一区二区在线观看 | 免费a视频在线观看 | 天天干天天爽 | 久久亚洲精品国产亚洲老地址 | 欧美日韩免费在线视频 | 亚州国产精品 | 四虎国产精品免费 | 激情xxxx| 日韩免费电影在线观看 | 99视频偷窥在线精品国自产拍 | 丁香影院在线 | 人人澡人人爽欧一区 | 色婷婷亚洲 | 午夜久久久久久久 | 国产精品系列在线 | 一区免费观看 | 久久影视一区 | 日韩一区二区三区免费视频 | 久久精品国产免费看久久精品 | 中文字幕在线免费观看视频 | 国产伦理一区二区三区 | 亚洲精品乱码久久久久久写真 | 91久久一区二区 | 91在线观看黄 | 激情婷婷亚洲 | www.伊人色.com | 成 人 黄 色 视频播放1 | 久草电影网 | 亚州av网站大全 | www久久久久 | 国产91亚洲 | 亚洲最大av网站 | 三三级黄色片之日韩 | 日本黄色免费看 | 久草9视频 | 五月综合婷 | 国产精品夜夜夜一区二区三区尤 | 九九影视理伦片 | 亚洲视频在线免费看 | 国产精品婷婷午夜在线观看 | 欧美人人| 亚洲精品理论片 | 精品国产一区二区三区av性色 | 免费观看日韩 | 福利视频一区二区 | 国产一级片视频 | 欧美伦理一区二区三区 | 在线观看免费成人 | 在线小视频你懂得 | 日韩在线观看视频中文字幕 | 国产精品岛国久久久久久久久红粉 | 天天综合网 天天 | 久久国产热视频 | 91传媒在线播放 | 天天天干天天射天天天操 | 亚洲永久精品国产 | 精品国产乱码久久久久久1区2匹 | 天天射天天操天天色 | 欧美在线视频一区二区三区 | www.夜夜草 | 91综合视频在线观看 | 久99视频 | 中文字幕亚洲高清 | 久久精品久久99精品久久 | 国产成人333kkk | 中文字幕二区三区 | 亚洲精品一区二区三区四区高清 | 成人av高清在线 | 国产福利午夜 | a级片在线播放 | 久久你懂得 | www在线免费观看 | 日本中文不卡 | 亚洲欧美经典 | 狂野欧美激情性xxxx | 91一区二区三区在线观看 | 新版资源中文在线观看 | 日韩高清免费在线观看 | 久久精品人 | 欧美在线不卡一区 | 奇米777777| 国产香蕉97碰碰久久人人 | 国产精品久久久久久爽爽爽 | 色资源网在线观看 | 国产精华国产精品 | 免费开视频 | 成人免费视频在线观看 | 99久久精品久久久久久动态片 | 国产精品av在线免费观看 | 3d黄动漫免费看 | 久草视频在线看 | 中文字幕字幕中文 | www久久国产 | 国产99久久精品 | 人人草在线视频 | 一区二区三区在线免费观看 | 成人久久亚洲 | 日本护士撒尿xxxx18 | 91色一区二区三区 | 五月婷婷影院 | 欧美a在线免费观看 | 成人午夜性影院 | 国产美女视频黄a视频免费 久久综合九色欧美综合狠狠 | 亚洲精品国产精品国自产在线 | 最近中文字幕完整高清 | 欧美在线观看禁18 | 日韩av电影网站在线观看 | 99热999| 国产欧美三级 | 国产精品久久久久久影院 | 欧美国产不卡 | 天天操天天干天天 | 成人在线超碰 | 在线视频免费观看 | www.夜色321.com | 久久精品网址 | 天天操天天干天天干 | 99久久久成人国产精品 | 在线一区观看 | 青青草在久久免费久久免费 | 国产精品福利久久久 | 久草精品国产 | 欧美精品xx| 天天插狠狠干 | 国产精品久久婷婷六月丁香 | 欧美资源在线观看 | 最新日韩视频在线观看 | 国产一级电影免费观看 | 久久图 | 一本一本久久a久久精品综合 | 国产精品久久久久久影院 | 亚洲激情在线观看 | 中文字幕人成人 | 亚洲精品久久久久久久不卡四虎 | 亚洲天堂精品视频 | 欧美日韩视频在线观看免费 | 99久久综合狠狠综合久久 | 亚洲天堂精品 | 在线国产欧美 | av电影免费在线播放 | 午夜三级影院 | 西西人体www444 | 首页国产精品 | 久久精品xxx | 美女网站在线免费观看 | 激情综合六月 | 国产精品18毛片一区二区 | 日韩网站在线 | 91最新网址在线观看 | 99情趣网视频 | 99精品视频在线观看播放 | 欧美极品在线播放 | 久久婷婷国产色一区二区三区 | 人人插人人爱 | 成人av免费看 | 日韩二区三区在线观看 | 午夜在线观看影院 | 日韩精品免费一区二区三区 | 久久99亚洲网美利坚合众国 | 日韩电影一区二区三区 | 国产精品99久久久久久久久久久久 | 久久成电影 | 黄污视频网站 | 久久国产影视 | 999久久国产 | 国产精品com | 99久久精品国| 在线免费黄网站 | 国产精品免费观看视频 | 婷婷av综合| 中文字幕亚洲欧美日韩2019 | 日韩精品久久中文字幕 | 18国产精品福利片久久婷 | 日韩av黄| 天天色天天上天天操 | 中文字幕日韩有码 | 国产99久久99热这里精品5 | 美女网站免费福利视频 | 人人澡超碰碰97碰碰碰软件 | 久久视影| 亚洲视频大全 | 中文在线www | 91人人人 | 久久久久久久久久久影视 | 日韩精品中文字幕在线不卡尤物 | 免费亚洲精品视频 | 久久精品视频国产 | 人人狠狠综合久久亚洲 | 免费看国产曰批40分钟 | 免费观看日韩 | 樱空桃av | 亚洲在线视频观看 | 91精品国产欧美一区二区 | 亚洲全部视频 | 婷婷六月天在线 | 婷婷丁香色综合狠狠色 | 人人爽人人爽人人片av | 9在线观看免费高清完整版在线观看明 | 粉嫩一区二区三区粉嫩91 | 天堂av免费在线 | 国产美女被啪进深处喷白浆视频 | 成人免费观看完整版电影 | 午夜视频在线观看一区二区三区 | 午夜影院三级 | 日本一区二区三区免费观看 | 2020天天干夜夜爽 | 天天天射| 婷色在线 | 日韩网站在线看片你懂的 | 免费精品久久久 | 天堂av网址 | bbbbb女女女女女bbbbb国产 | 久久免费美女视频 | 免费的国产精品 | 久久久久久伊人 | 狠狠的日日 | 久久久不卡影院 | 天天干天天做天天爱 | 精品99免费视频 | 一区 在线 影院 | 日韩在线欧美在线 | 久久久久久欧美二区电影网 | 国内精品久久久久影院一蜜桃 | 国产成人精品一二三区 | 成年人免费在线 | 午夜久久精品 | 国产二区精品 | 午夜精品福利一区二区 | 婷婷色站 | 日本精品视频网站 | www日日 | 午夜在线免费观看视频 | 天天干天天操 | 日韩av午夜在线观看 | www夜夜操com | 亚洲欧洲av在线 | 国色天香在线观看 | 亚洲首页 | 天天操网址| 黄色大片日本免费大片 | 国产精品美女久久久久久久久久久 | 激情五月在线视频 | 97视频在线观看成人 | 日韩精品在线观看视频 | 欧美日韩国产精品一区 | 欧美污网站 | 久久久电影网站 | 免费看黄的 | 婷婷久久网 | 国产流白浆高潮在线观看 | 成人a级免费视频 | 精品九九久久 | 中文字幕在线免费观看视频 | 午夜精品一区二区三区在线观看 | 色香蕉在线 | 91精品久久久久久综合乱菊 | 奇米777777 | 射射射av | 一级a性色生活片久久毛片波多野 | 999热视频| 美女一级毛片视频 | 国产我不卡| 天天射综合 | 天天天色综合a | 天天综合成人 | 全黄色一级片 | 在线小视频你懂得 | 成人一区影院 | 色综合欧洲 | 香蕉视频久久 | 96精品在线 | 久久欧洲视频 | 国内精品久久久久久久 | 亚洲综合在线播放 | 日韩免费在线网站 | 国产99久久久精品 | 免费观看黄色12片一级视频 | 香蕉蜜桃视频 | a久久免费视频 | 久久久久亚洲精品成人网小说 | 久久艹国产 | 国产精品一区二区在线免费观看 | 久久手机精品视频 | 国产精品孕妇 | 亚州国产精品视频 | 久久精品99精品国产香蕉 | 超碰九九 | 国产中文字幕网 | 欧美一级网站 | 成人一区不卡 | 色94色欧美 | 久久久久久高潮国产精品视 | 欧美色婷| 亚洲最大在线视频 | 日韩视频一 | 国产高清小视频 | 欧美日韩精品二区第二页 | 日韩有码欧美 | 久草视频免费观 | 91最新地址永久入口 | 干 操 插 | 午夜视频欧美 | 日韩在线观看免费 | 91av大全| 亚洲免费av网站 | 久草国产视频 | 骄小bbw搡bbbb揉bbbb | 日韩精品在线播放 | 成人国产精品入口 | 91免费观看视频网站 | 久久久久久久久黄色 | 在线看的av网站 | 日韩电影中文字幕在线 | 久草视频2 | 久久综合国产伦精品免费 | 日韩欧美在线综合网 | 99精品福利 | 天天色天天骑天天射 | 久久婷婷开心 | 国产资源网站 | 碰碰影院 | 色多多污污在线观看 | 91精品国产九九九久久久亚洲 | 成人国产网址 | 97超碰资源 | 国产粉嫩在线观看 | 在线观看日韩免费视频 | 亚洲精品高清在线 | 69国产盗摄一区二区三区五区 | adn—256中文在线观看 | 日韩在线视 | 国产成人精品在线播放 | 色综合天天狠天天透天天伊人 | 91精品在线麻豆 | 免费看黄色91 | 日韩a在线播放 | 粉嫩一区二区三区粉嫩91 | www.激情五月.com | 久草精品免费 | 成人av免费在线观看 | 中文字幕五区 | 日韩精品一区二区三区在线视频 | 在线观看亚洲国产 | 亚州欧美精品 | 久久亚洲成人网 | 精品少妇一区二区三区在线 | 97视频人人 | 亚洲国产成人高清精品 | 99视频网址 | 久久久99精品免费观看 | 国产精品色婷婷视频 | 热久久免费国产视频 | 国产精品www | 亚洲欧洲在线视频 | а天堂中文最新一区二区三区 | 91污在线| 国产69精品久久99不卡的观看体验 | 91自拍91 | 午夜黄色影院 | 国产美女精品久久久 | 天天爽天天碰狠狠添 | 人人爽人人爽人人爽 | 日韩美女一级片 | 成人欧美一区二区三区在线观看 | 99这里精品 | 国模吧一区 | 欧美成人h版在线观看 | 韩国av免费观看 | 在线 国产一区 | 在线亚洲欧美日韩 | 欧美激情综合色综合啪啪五月 | 欧美日韩一区二区在线观看 | 日韩在线观看中文 | 超碰97国产在线 | 国产香蕉97碰碰碰视频在线观看 | 国产高清精品在线观看 | 成人免费在线视频 | 久久久久久麻豆 | 99精品亚洲| 在线观看成人小视频 | 国产999视频在线观看 | 韩国av免费 | 成人av在线电影 | 亚洲国产精品久久久久 | 日产乱码一二三区别在线 | 成年人在线免费看视频 | 亚洲黄色小说网 | 99亚洲精品视频 | 中文字幕九九 | 国产黄在线 | 成年人免费av | 国产精品福利久久久 | 成人网在线免费视频 | 亚洲精品在线看 | 婷婷伊人综合 | 500部大龄熟乱视频使用方法 | 国产免费不卡 | 黄色成人在线观看 | 久久精品一二三区白丝高潮 | 91麻豆精品国产91久久久无限制版 | 国产黄在线免费观看 | 在线观看电影av | 99精品视频网站 | 成人午夜网址 | 亚洲成av人影院 | 免费观看一级成人毛片 | 亚洲精品动漫久久久久 | 精品国产视频一区 | 人成在线免费视频 | 国产精品一区二区三区免费视频 | 天天草夜夜 | 91福利视频在线 | 91大神免费视频 | 亚洲精品在线免费观看视频 | 伊甸园永久入口www 99热 精品在线 | 欧美极品少妇xxxx | 国产精品视频永久免费播放 | 欧美性高跟鞋xxxxhd | 成人av电影免费在线播放 | 午夜久久久久久久久久久 | 99久久精品国产免费看不卡 | 国产小视频91 | 国产亚洲久久 | 久久久精品一区二区三区 | 黄色免费电影网站 | 成片免费观看视频 | av大全在线观看 | 天天激情综合网 | 免费瑟瑟网站 | 国产精品久久久久久吹潮天美传媒 | www.com黄色| 丁香激情婷婷 | 久久超碰在线 | 91视频久久 | 日韩精品一区二区不卡 | 亚洲五月 | 91福利国产在线观看 | 黄色片网站免费 | 97热久久免费频精品99 | 国产福利免费在线观看 | 久草剧场 | 亚洲成av人片一区二区梦乃 | 成人在线电影观看 | 色欧美日韩 | 国产在线观看网站 | 国产成人精品午夜在线播放 | 亚洲免费av网站 | 伊人资源站 | 久久久久北条麻妃免费看 | 99婷婷 | 久久兔费看a级 | 黄色免费观看 | www.黄色片网站 | 一区二区三区日韩精品 | 人人干网站 | 久久成人亚洲欧美电影 | 亚洲国产精品人久久电影 | 国产一二三精品 | 久草在线免费播放 | 亚洲黄色三级 | 欧美视频在线二区 | 久久人人爽人人爽 | 色综合久久久久综合体桃花网 | 国产精品扒开做爽爽的视频 | 国产福利久久 | 日本精油按摩3 | 色网免费观看 | 五月婷婷狠狠 | 国产乱码精品一区二区三区介绍 | av综合av| 中文在线字幕免费观看 | 国产18精品乱码免费看 | av电影在线播放 | 97碰视频| 亚洲免费av片 | 69av免费视频 | 久草爱 | 一区二区三区电影 | av三区在线 | 午夜电影中文字幕 | 精品国产一区二区三区久久久久久 | 国产午夜精品一区二区三区嫩草 | www.五月婷婷 | 天天色天天艹 | 99精品成人 | 精品国产一二三四区 | 国产成人精品免费在线观看 | 特黄特黄的视频 | 日本在线观看中文字幕无线观看 | 国产在线综合视频 | 91中文字幕在线播放 | 最近更新好看的中文字幕 | 久久免费精彩视频 | 日韩视频在线一区 | 色多多污污在线观看 | 国产精品观看在线亚洲人成网 | 日韩夜夜爽| 亚洲第一中文字幕 | 久要激情网 | 人人看97 | 日韩3区| 免费黄色小网站 | 激情视频免费观看 | 久久激情视频网 | 鲁一鲁影院 | 午夜久久影院 | 国产精品99精品久久免费 | 97超碰在线免费观看 | 国产免费不卡av | 久久av影视 | 中文字幕国产精品一区二区 | 婷婷久久精品 | 五月天激情视频在线观看 | 欧美在线视频不卡 | 欧美精品少妇xxxxx喷水 | 国产在线欧美 | 91在线www | 少妇精品久久久一区二区免费 | 青春草免费在线视频 | 亚洲成av人片在线观看www | 三级黄色在线 | 六月丁香婷婷在线 | 一区二区三区免费网站 | 国产成人高清 | 91精品国| 精品国产伦一区二区三区 | 天天操狠狠操网站 | 久草在线视频看看 | av高清网站在线观看 | 五月婷婷,六月丁香 | 国产探花视频在线播放 | 夜夜躁狠狠躁日日躁视频黑人 | 久久99电影 | 天天摸夜夜添 | av免费观看网站 | 国产婷婷久久 | 91探花国产综合在线精品 | 欧美激情视频在线免费观看 | 久久免费国产精品1 | 亚洲精品国久久99热 | 毛片无卡免费无播放器 | 久久亚洲精品国产亚洲老地址 | 2022久久国产露脸精品国产 | 天天综合天天做 | 欧美91成人网 | 中文字幕在线看视频国产 | 久久最新网址 | 91免费高清视频 | 波多野结衣网址 | 亚洲精品理论 | 亚洲婷婷在线视频 | 久久视频在线视频 | 日韩有码专区 | 色www精品视频在线观看 | 日韩高清一二三区 | 久久国产欧美日韩精品 | 国产一区视频导航 | 欧美性色网站 | 国产色视频网站2 | 国产一区二区久久久久 | 成人小视频在线播放 | 在线亚洲激情 | 国际av在线 | 国产麻豆传媒 | 激情综合五月网 | 天天天天干| av免费看在线 | 国产a级片免费观看 | 一本一道久久a久久精品 | 五月天综合网站 | 人人添人人澡 | 又黄又色又爽 | 91欧美在线 | 国产黄色免费观看 | 欧美999| 国产日韩欧美在线播放 | 中文字幕资源在线 | 成人免费视频免费观看 | 国产精品免费久久久 | 国产资源在线免费观看 | 国产精品久久久久久久久软件 | 国产精品一区二区免费 | 五月婷婷亚洲 | 国产做a爱一级久久 | 美女天天操| 99精品国产福利在线观看免费 | 免费中文字幕 | 免费看成人 | 丝袜+亚洲+另类+欧美+变态 | 久精品在线观看 | av电影一区二区三区 | 五月黄色| 日韩中文字幕在线观看 | 国产综合小视频 | 精品久久久久久久久久国产 | 国产主播大尺度精品福利免费 | 亚洲人久久 | 欧美日韩国产一区二区三区在线观看 | 爱色av.com | 在线影院av | 亚洲精品美女 | 视频一区二区三区视频 | 国产99精品在线观看 | www.夜夜爽 | 夜夜躁日日躁狠狠久久av | 亚洲va在线va天堂 | 久久试看 | 日日草天天干 | 国产无遮挡又黄又爽在线观看 |