python第四课笔记

先交代一下上次课留下的作业:

登陆界面

def menu():
    #用来显示操作界面
    while True:

        opt = input("晴选择要进行的操作:\n(1)注册\n(2)登陆\n(3)退出\n")
        if opt =="1":
            register()
        if opt =="2":
            denglu()
        if opt =="3":
            print("Bye~~")
            break

这里使用while true很关键,能够让界面跳出去而不是一直在循环

users = []

定义出一个元组,使输出的形式为{'username‘:'','pwd':''}这样

def read_username():
    #获取用户输入的用户名

    username = input("请输入用户名:\n")
    if len(username)<6 or len(username)>9:
        print("用户名长度有误")
        return read_username()#这就是递归,继续重复这个函数

    name_list = [user.get('username')for user in users]
    if username in name_list:
        print("该用户已存在")
        return read_username()

    return username

保证录入的用户名是符合要求的

def register():
    username = read_username()
    pwd = read_pwd()
    user = {}
    user['username'] = username
    user['pwd'] = pwd
    users.append(user)#这一步才正式向users里加入了注册信息
    print("注册成功")

    print(users)
def read_pwd():
    pwd1 = input("请输入密码:\n")
    if len(pwd1)<6 or len(pwd1)>9:
        print("密码长度有误")
        return read_pwd()
    return pwd1

def find_user_by_name(username):
    for user in users:
        if user['username'] == username:
            return user

    return None

def get_user_by_username():
    username = input("请输入用户名:\n")
    user = find_user_by_name(username)
    if user is None:
        print("用户不存在")
        return get_user_by_username()
    return username

用以上两个函数确保登陆时输入的信息跟注册时的一致

def denglu():
    username = get_user_by_username()
    pwd = input("请输入密码:\n")
 print("登陆成功")
    dengluchenggong()


def dengluchenggong():
    while  True:
        opt = input("请选择你想进行的操作:\n(1)查看当前用户信息\n(2)查看用户列表\n(3)退出登陆")
        if opt == 1:
            user_list()

        if opt ==2:
            denglu()
        if opt == 3:

            print("再见吧您")

def user_list():
    for user in users:
        print(user)
menu()

最后一步才是主体,其他都是在定义函数

第二题商品打折,比较好做

products = [{"pname":"笔记本","number":2,'price':2.5},{"pname":"手机","number":1,'price':1800}]

def twozhe(totprice):
    print("打两折")
    return totprice*(1-0.2)

def threezhe(totprice):
    print("打三折")
    return totprice*(1-0.3)

def huodong(price,zhekou = None):
    if zhekou ==None:
        return price
    return zhekou(price)


def app():
    totnum = sum([item['number'] for item in products])
    totprice = sum([item['price']for item in products])
    zhekou = None

    if totnum>2:
        zhekou = twozhe
    if totprice>1000:
        zhekou = threezhe


    price = huodong(totprice,zhekou)
    print("总价:%f"%price)

app()

面向对象

面向对象是一种编写代码的思维方式:程序是由什么构成的。
类,其实是一种抽象
User类:把用户相关信息抽象到一起
类名都采用驼峰结构,并且首字母大写
一般来说,类由属性和方法组成,属性表示了类的特点,方法和行为规定了类的功能
程序 = 数据结构(属性)+算法(行为和方法)
函数定义在类里称为方法
类->实例:实例是类的具体化
self指的是:当前对象(方法的调用者),即谁调用这个类就指的是谁

class Cat:
    #构造方法,该方法会在创建对象(实例)的时候,自动调用
    def __init__(self,color,name):
        self.color = color
        self.name = name
    def catch_rat(self):
        print(self.name + "抓到了老鼠")

创建一个实例(对象)

tom = Cat('blue','tom')
tom.catch_rat()

实例化对象的过程:1.分配内存出来(new) 2.初始化值(init)

私有属性

print(tom.name)#tom
tom.name = 'jiafei'
print(tom.name)#jiafei  没有私有化,属性可以被更改

属性私有化

1.用__两个下划线开头,如_name 2.自己约定单下划线
这样属性访问不了,打印会报错,更无法更改
双下划线为什么可以隐藏变量?dict,里面装的实例的所有属性

print(tom.__dict__)#{'color': 'blue', 'name': 'jiafei'}

双下划线开头的属性,会被名称转换:_类名+属性名

class Student:
    def __init__(self,name,age):
        self.__name = name;
        self.__age = age
    def set_name(self,name):
        if not len(name)<3:
            self.__name = name
    def get_name(self):
        return self.__name
    def age(self):
        print("年龄")
        return self.__age
    def set_age(self,age):
        if age > 0 and  age < 100:
            self.__age = age
s = Student("zhangsan",20)
print(s.get_name())#zhangsan
s.set_name("lisi")
print(s.get_name())#lisi  名字被修改
s.age = 40
print(s.age)

类也是对象
self.属性名: 实例属性
在类里直接定义属性,称为类属性,类属性由所有对象共享

class User:
    num = 0
    def __init__(self,name):
        self.name = name
        User.num += 1
    def print_name(self):
        print(self.name,User.num)
    @classmethod
    def create_user(cls,name,age):
        user = cls(name)
        user.name = name
        user.age = age
        return user
u = User("zs")
u.print_name()
u1 = User('1s')
u1.print_name()
User.num += 1
u1.print_name()
u2 = User.create_user('zs',20)
print(u2.age)
print(u2.name)
u3 = u1.create_user('zs',20)
print(u3.age)
#类方法也可以用实例调用

@classmethod 修饰的方法是类方法,类方法可以通过类名调用,类方法必须有一个类型参数:cls
@staticmethod 修饰的是静态方法,通过类名可以访问,当做普通函数就行

继承

python 支持多继承,继承内容与继承顺序相关
所有的类,都会默认继承object类

class A:
    def __init__(self):
        self.name = 'zs'
    def print_test(self):
        print("aaaaaaa")
class B:
    def __init__(self):
        self.name = "ls"
class C(B,A):
    def __init__(self):
        super().__init__()
        self.age = 20
    def print_test(self):
        super().print_test()
        print("ewrewrewr")
c= C()
print(c.name)#zs  c继承了A的内容
print(c.age)#20  c仍然有自己的内容
print(C.__mro__)#(<class '__main__.C'>, <class '__main__.A'>, <class 'object'>)

调用属性或方法的查找顺序

c.print_test()

组合优于继承

class D:
    def __init__(self):
        self.a = A()
    def print_test(self):
        self.a.print_test()
        print("dfdsfdsfsdf")
d = D()
d.print_test()

模拟一个游戏,有一个怪兽(monster),还有一个玩家(hero)

import random as rn
class gghero:
    def __init__(self,name):
        self.blood = 100
        self.power = 12
        self.name = name
    def attack(self,monster):
        minus = rn.randrange(self.power-5,self.power+5)
        if monster.has_living():
            monster.minus_blood(minus)
        print(monster.name + ":" + str(monster.blood))
    def minus_blood(self,num):
        self.blood-=num
    def has_living(self):
        if self.blood >0:
            return True
        return False

当允许使用道具时

m = gghero("哥斯拉")
h = gghero("奥特曼")
while m.has_living() and h.has_living():
    m.attack(h)
    h.attack(m)
if m.has_living():
    print(m.name + "获得胜利")
if h.has_living():
    print(h.name + "获得胜利")
class hero(gghero):
    def bug_attack(self,monster):
        monster.minus_blood(monster.blood)
    def attack(self,monster):
        super().attack(monster)
        num = rn.randint(0,3)
        if num == 1:
            print(self.name + "使用了道具")
            self.bug_attack(monster)
class monster(gghero):
    pass
hero = hero("antoman")
monster = monster("gesila")
#m = gghero("哥斯拉")
#h = gghero("奥特曼")
while hero.has_living() and monster.has_living():
    hero.attack(monster)
    monster.attack(hero)

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

推荐阅读更多精彩内容