day_1 实现User类 Item类 DBHelper类

之前没有记着边学边写笔记,没有这样的习惯,现在来培养下。之前写了不少了,先贴上代码,之后再来补上具体的其他的。而且对于这里的笔记,不在考虑结构内容啥的,写完一个功能就会来总结下。还会有些突发奇想在里面,就像是得知自己癌症晚期后,想要记录自己的一切的那种想法是一样的想法。

User类

将所有的属性设置为非公开的属性,然后写get和set公开方法来提供公共的借口,但是我还没有写完,

class User:
    """用户"""
    def __init__(self, name: str, number: str, password: str, balance: float):
        self._user_name = name
        self._user_number = number
        self._password = password
        self._balance = balance

    def get_name(self) -> str:
        return self._user_name

    def set_name(self, new_name) -> bool:
        self._user_name = new_name
        return True

    def get_number(self) -> str:
        return self._user_number

    def get_balance(self) -> float:
        return self._balance

    def set_balance(self, new_balance):
        self._balance = new_balance
        return True

    def get_password(self):
        return self._password

    def __str__(self):
        s = "用户名:" + self.get_name() + "\t卡号:" + self.get_number() + \
            "\t余额:" + str(self.get_balance())
        return s


if __name__ == '__main__':
    user = User("张三", "123421", "124422", 12.0)
    print(user)

Item类

from datetime import datetime
from User import User


class Item:
    """定义日志类"""
    def __init__(self, user, type, money, status):
        self._time = str(datetime.now())
        self._user = user
        self._type = type
        self._money = money
        self._status = status

    def get_time(self):
        return self._time

    def get_user(self):
        return self._user

    def get_type(self):
        return self._type

    def get_money(self):
        return self._money

    def get_status(self):
        return self._status

    def __str__(self):
        s = "[" + self.get_time() + "]  " + self.get_user().get_name()\
            + "  |  " + self.get_type() + "  |  " + self.get_money() \
            + "  |  " + self.get_status()
        return s


if __name__ == '__main__':
    user = User("DK", "1433223", "123456", 1000)
    item = Item(user, "存款", 100, "成功")
    print(item)

DBHelper类

这类还挺复杂的

from config import *
import pymysql as msql
from Item import Item
from User import User


class DBHelper:
    """数据库助手,存数据,取数据"""
    # -----------------------------默认直接链接数据库-------------------------
    def __init__(self):
        self.connect = msql.connect(host=MYSQL_HOST, user=MYSQL_USER,
                                    port=MYSQL_PORT, password=MYSQL_PASSWORD,
                                    db=MYSQL_DATABASE,
                                    charset=MYSQL_DATABASE_CHARSET)
        self.cursor = self.connect.cursor()

    # ----------------------user对象的增删改查--------------------------------
    def get_user(self, number: str) -> User:
        """查"""
        self.connect.ping(reconnect=True)
        sql = 'SELECT * FROM user ' \
              'WHERE number=(%s)' % number
        # self.connect.begin()
        self.cursor.execute(sql)
        result = self.cursor.fetchone()
        if result:
            user = User(number=result[0], name=result[1], password=result[2],
                        balance=result[3])
            return user

    def insert_user(self, user: User):
        """增""" 
        number = user.get_number() 
        name = user.get_name() 
        password = user.get_password() 
        balance = user.get_balance() 
        # print(number, name, password, balance) #
        self.connect.ping(reconnect=True) 
        sql = "INSERT INTO user(number, name,password, balance)" \
         "VALUES('%s', '%s', '%s', '%f')"\
          % (number, name, password, balance)

        try:
            self.connect.begin()
            self.cursor.execute(sql)
            self.connect.commit()
        except Exception as e:
            print("新用户注册失败")
            print(e.args)
            self.connect.rollback()
            return False
        return True

    def del_user(self, number: str):
        """删"""
        sql = " DELETE FROM user WHERE number=%s" % number
        try:
            self.connect.begin()
            self.cursor.execute(sql)
            self.connect.commit()
        except Exception as e:
            print("用户销户失败")
            print(e.args)
            self.connect.rollback()
            return False
        return True

    def update_user(self, change_item: str, change_value: str):
        """改"""
        sql = "UPDATE user SET " + change_item + "=" + change_value
        try:
            self.connect.begin()
            self.cursor.execute(sql)
            self.connect.commit()
        except Exception as e:
            print("用户信息更改失败")
            print(e.args)
            self.connect.rollback()
            return False
        return True

    # --------------------item记录的增删查-----------------------------
    def insert_log(self, item: Item):
        """新加一条记录"""
        number = item.get_user().get_number()
        time = item.get_time()
        name = item.get_user().get_name()
        type = item.get_type()
        money = item.get_money()
        status = item.get_status()
        balance = item.get_user().get_balance()
        sql = "INSERT INTO log (number, time, name, type, money, status, " \
              "balance)" \
              "VALUES('%s', '%s', '%s','%s', '%f', '%s', '%f')" \
              % (number, time, name, type, money, status, balance)
        try:
            self.connect.begin()
            self.cursor.execute(sql)
            self.connect.commit()
        except Exception as e:
            print("日志记录失败")
            print(e.args)
            self.connect.rollback()
            return False
        return True

    def del_all_logs(self, number):
        """删除用户的所有记录,仅用于销户"""
        sql = "DELETE FROM lOG WHERE numbers="+number
        try:
            self.connect.begin()
            self.cursor.execute(sql)
            self.connect.commit()
        except Exception as e:
            print("删除用户操作记录失败")
            self.connect.rollback()
            print(e.args)
            return False
        return True

    # --------------------关闭数据库的连接-------------------------------
    def close(self):
        self.connect.close()


if __name__ == '__main__':
    db = DBHelper()
    user = User("张三", "123321", "971221", 1200)
    item = Item(user, "存款", 1000, "成功")
    db.insert_log(item)
    db.close()

除此之外,还有数据库的相关配置,用来连接数据库。

# 用来保存相关的设置,数据库的相关信息等
MYSQL_HOST = 'localhost'
MYSQL_PORT = 3306
MYSQL_PASSWORD = 'password'
MYSQL_USER = 'root'
MYSQL_DATABASE = 'atm'
MYSQL_DATABASE_USER = "user"
MYSQL_DATABASE_LOG = 'log'
MYSQL_DATABASE_CHARSET = 'utf8'

DBHelper还没有实现完

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,772评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,458评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,610评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,640评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,657评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,590评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,962评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,631评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,870评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,611评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,704评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,386评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,969评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,944评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,179评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,742评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,440评论 2 342

推荐阅读更多精彩内容