python买东西_Python实战之ATM+购物车

学python一个月以来的第一个工程级别项目!!!!!

1.首先分析项目需求:

模拟实现一个ATM + 购物商城程序

额度 15000或自定义---->注册功能

实现购物商城,买东西加入 购物车,调用信用卡接口结账----->购物车,支付

可以提现,手续费5%----->提现

支持多账户登录----->登录

支持账户间转账----->转账

记录日常消费流水----->记录流水

提供还款接口---->还款

ATM记录操作日志---->日志

提供管理接口,包括添加账户、冻结账户等。。。---->管理接口,添加,冻结账户

用户认证用装饰器------>装饰器

用软件功能表达就是:

1、登录

2、注册

3、查看余额

4、转账

5、还款

6、取款

7、查看流水

8、购物

9、查看购买商品

2.设计程序以及程序的架构

3d10a4ba144e

购物车架构图

通过架构图来设计软件:

3d10a4ba144e

程序结构

3.程序结构:

ATM:程序的根目录

conf:配置文件

setting:放置配置文件,日志字典,日志与db路径

core:核心代码

src.py:核心功能的主体代码,为用户展示功能以及让用户选择,并与用户交互,接收用户输入的数据

在取款/转账/购物完成以后可以在后面加上将此信息加入到该账户的流水(用户接口层注册里面的bankflow)列表中去.

db:数据操作

db_handler.py:数据处理层,里面包含两种方法:save(),传入用户信息字典,存入硬盘..select():传入姓名,若用户存在,返回用户信息字典,若不存在,返回False

wzj.json:存放wzj用户信息的文件,包含内容{用户名,密码,余额,信用卡额度,交易流水,购物车信息,是否锁定}

inter_face:接口层

bank.py:银行接口,包含方法有:

withdraw_interface(money):取款接口:调用src里的登录用户的账户名通过调用db_handler.select方法查询到用户全部信息,更改完余额以后再调用db_handler.save方法重新存入文件

transfer_interface(add_name, money),转账接口

check_balance_interface(),擦看余额接口

check_record_interface(),查看流水接口

user.py:用户接口,包含两个方法

1.用户注册时传入的账号密码,通过调用db_handler里的方法判断,若账户不存在,则写入文件,若存在,则返回用户名已存在,,,,

2.登录时传入用户名与密码,通过调用db_handler里的方法与数据库中的信息匹配

lib:库

common.py:存放常用的函数,当作模块给其他文件调用

log:存放日志文件

readme:软件说明书

start.py:程序入口

4.主要代码

3d10a4ba144e

bank-->取款接口

3d10a4ba144e

转账接口

3d10a4ba144e

用户接口

3d10a4ba144e

数据操作,用于读写数据

5.购物与支付

在src文件里取到合法的购物车信息与商品总价格后,传入购物车接口,通过调用bank里面的支付接口判断,若余额足够则购买成功,否则返回余额不足

3d10a4ba144e

src里的购物代码

3d10a4ba144e

购物车接口

总结!!!

ATM的他的精髓就在于整个软件分为三层,,用户交互层,只负责接收合法数据传入接口层,接口层只负责处理数据,数据处理层只负责处理数据,这样扩展性极强,,比如我现在是在cmd里运行,如果移植到前端或者安卓里,只需要修改下用户交互层就可以

注意:用户交互层不能直接修改数据,只能通过调用接口,让接口负责修改数据

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

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

相关文章

multi source replication mysql_MySQL 5.7多源复制(Multi-Source Replication)

MySQL5.7.6以后开始支持多源复制Multi-Source Replication,可以将多个主的库同步到一台slave上,从而增加从的利用率,出节省了机器,也可用于备份。首先设置master_info_repository和relay_log_info_repository两个参数,这存储同步信…

列模式 文本编辑器_UltraEdit 24.2 文本编辑器免费版

UltraEdit是由IDM官方最新出品的文本编辑器版本,它是一款性价比全球一流的文本、十六进制,HTML、PHP、Java 和 JavaScript程序文本编辑器,被认为是世界上最好的文本编辑器。UltraEdit可以满足您的所有需求,例如代码突出显示&#…

在linux中加固mysql_mysql在linux下的安装

安装环境:系统是 centos6.51、下载下载地址:http://dev.mysql.com/downloads/mysql/5.6.html#downloads下载版本:我这里选择的5.6.33,通用版,linux下64位也可以直接复制64位的下载地址,通过命令下载&#x…

mysql 多条记录选择一套_2020-11-09-Mysql(练习题第一套)

遗留问题 select语句中的别名问题 group by 中的别名问题# sql-表 FACT_DAY_SC-字段 DEPT_ID varchar(20) 电厂TJSJ_DATE DATE 日期FSL number 日发电量create table FACT_DAY_SC(DEPT_ID varchar(20),TJSJ_DATE DATE,FSL LONG);insert into FACT_DAY_SC values (10001,2020-12…

wamp的mysql触发器教程_wamp里的mysql怎么做出这个

这个表怎么做这个是phpmyadmin,他是一个独立的程序,并不是wamp独有的,你也可以独立下载phpmyadmin来使用。首先,phpmyadmin你可以把他看作是一个php写的mysql管理工具。前端页面实际上就是HTML,和一般的网页没有什么区…

wx轮播图接口学习用json格式_零基础学小程序008----列表和轮播图的实现,小程序解析json数据...

点击下面网址进入系列教程上一节带领大家实现领简单的计算器,这节来带领大家学习小程序列表功能。本节知识点1,定义本地json文件2,本地文件引入3,小程序列表渲染实现4,解析本地json(为解析网络json做准备)学习之前先来…

云服务器怎么装mysql_云服务器(windows环境)安装mysql图文教程

1、首先进入的是安装引导界面2、然后进入的是类型选择界面,这里有3个类型:Typical(典型)、Complete(完全)、Custom(自定义)。这里建议选择“完全”(Complete)安装,这样可以自定义选择MySQL的安装目录,然后点“Next”下一步&#x…

阿里mysql 二进制_Mysql binlog 之阿里canal

1、What is Canal?canal [kənl],中文翻译为 水道/管道/沟渠/运河,主要用途是用于 MySQL 数据库增量日志数据的订阅、消费和解析,是阿里巴巴开发并开源的,采用Java语言开发;历史背景是早期阿里巴巴因为杭州…

java 基本类型 引用类型_Java中的基本类型和引用类型变量的区别

基本类型:基本类型自然不用说了,它的值就是一个数字,一个字符或一个布尔值。引用类型:是一个对象类型,值是什么呢?它的值是指向内存空间的引用,就是地址,所指向的内存中保存着变量所…

mysql 学生成绩等级_JSP+SSM+Mysql实现的学生成绩管理系统

项目简介本系统是基于JSPSSMMysql实现的学生成绩管理系统。主要实现的功能有教师管理、学生管理、课程管理、学生成绩管理。难度等级:中等技术栈编辑器Eclipse Version: 2020-03 (4.15.0)前端技术基础:htmlcssJavaScript框架:JQueryH-ui后端技…

java ajax 导出excel文件_springMVC(4)---生成excel文件并导出

springMVC(4)---生成excel文件并导出在开发过程中,需要将数据库中的数据以excel表格的方式导出。首先说明。我这里用的是Apache的POI项目,它是目前比较成熟的HSSF接口,用来处理Excel对象。其实POI不仅仅只能处理excel,它还可以处理…

java swing 模拟发牌_用java设计一个发牌程序

展开全部// 发牌程序。import java.awt.*;import java.awt.event.*;import javax.swing.*;public class CardBuffer //加互斥锁的缓冲区{private int value;private boolean isEmpty true; //value是否为空的信号量private int order0; //信号量,e68a8462616964757…

Java写文件导致io过高_161108、Java IO流读写文件的几个注意点

平时写IO相关代码机会挺少的,但却都知道使用BufferedXXXX来读写效率高,没想到里面还有这么多陷阱,这两天突然被其中一个陷阱折腾一下:读一个文件,然后写到另外一个文件,前后两个文件居然不一样?…

java接口测试框架搭建_接口自动化测试框架搭建

一、原理及特点参数放在XML文件中进行管理用httpClient简单封装一个httpUtils工具类测试用例管理使用了testNg管理,使用了TestNG参数化测试,通过xml文件来执行case。测试报告这里用到第三方的包ReportNG 项目组织用Maven二、准备使用工具:ecl…

java工厂模式 uml_深入浅出设计模式-简单工厂模式

模式定义简单工厂模式是属于创建型模式,又叫做静态工厂方法(Static Factory Method)模式,但不属于23种GOF设计模式之一。简单工厂模式定义了一个创建对象的类,由这个类来封装实例化对象的行为。设计原则遵循的原则:依赖倒置原则迪…

java技术难点_Java核心技术第四章----对象与类重难点总结

一、类之间的关系类和类之间的关系,耦合度从高到低:is -a。继承、实现has-a。组合、聚合、关联user-a。依赖。要求是:高内聚、低耦合。继承(“is-a”)继承(Inheritance),即“is-a”关系,是一种用于表示特殊与一般关系的…

java日志级别的作用_Java系统日志级别对性能的影响性

先介绍下java系统的日志日志框架:是一种日志接口,不负责具体的日志输出形式(有点类似于JDBC),可以灵活的切换日志输出形式。常见的日志框架有slf4j、jcl,只提供Logger、LoggerFactory等接口日志系统:是应用实际使用的日…

java用链表做学生系统_C语言链表实现学生管理系统

本文实例为大家分享了C语言链表实现学生管理系统的具体代码,供大家参考,具体内容如下#include#include#include#include#include#includeusing namespace std;typedef struct ndoe{char id[10];char name[10];char sex[3];char num[10];struct node *nex…

mysql 全文本检索的列_Mysql 全文本检索

mysql 全文索引注意 并非所有的引擎都支持 全文检索mysql最常用的引擎 INnodb 和 myisam 后者支持全文检索 前者不支持创建表的时候指定要检索列 CREATE TABLE TEST_FULLTEXT(note_id int not null auto_increment,note_text text null, primaty key(note_id),FULLTEXT(note_te…

java 的对象类用_java基础(第零篇)对象与类

前言:本文讲述java中对象与类的一些概念。包括对象与类的有关概念,类间五种关系,类的访问权限等。在java中,一切都可以用对象来描述,操作对象的标识符只不过是对象的一个引用,一个对象可以有多个引用&#…