2018-03-17

2018-03-19  本文已影响0人  裴general

python第三周学习总结

函数

默认参数:调用函数时,如果没有传递参数,则使用默认值参数
可变参数:函数参数不定长的参数(args)
关键字参数:函数的调用者可以传入任意不受限制的关键字参数 kwages
命名关键字参数:关键字参数和函数调用关系紧密,函数调用使用关键字参数来确定传入的参数值(def foo( a, b, * , name, age)),和关键字参数
kw不同,命名关键字参数需要一个特殊分隔符
,*后面的参数被视为命名关键字参数

def foo(a, b, c, *, name, age):# *是分隔符,前面的参数爱给不给,后面的参数一定要给
    print(a + b + c)
    print(name, ':', age)
# 如果希望将一个字典作为关键字参数传入,需要在参数前放置  ** 
 。(foo(**dict1))
# 列表也是同理进行处理,放置一个 *   。(foo(*list1))

类和对象

类和实例

class Teacher(object):
    def __init__(self, name , age, title):
        self._name = name
        self._age = age
        self._title = title

5,数据封装:直接操作了对象内部的数据,但无需知道方法内部的实现细节

@property
    def name(self):
        return self._name

6,继承: 从已经有的类创建新类的过程

提供继承信息的称为父类(超类/基类, 得到继承信息的称为子类(派生类/衍生类)。通过继承我们可以讲子类中的重读代码抽取到父类中,子类通过继承并复用这些代码来减少重复代码的编写,将来如果要维护子类的公共代码只需要在父类中进行操作即可。

 class Student(Person):
     def __init__(self, name, age):
         super().__init__(name, age) #调用父类方法
         self._grade = grade

7,方法重写:子类在继承父类方法之后 对方法进行了重新实现

class Parent:        # 定义父类
   def myMethod(self):
      print ('调用父类方法')
 
class Child(Parent): # 定义子类
   def myMethod(self):
      print ('调用子类方法')
 
c = Child()          # 子类实例
c.myMethod()         # 子类调用重写方法
super(Child,c).myMethod() #用子类对象调用父类已被覆盖的方法

8,装饰器:decorator

# 高阶函数 - f(g(x))
# 高内聚:一个函数只做好一件事,该做的是
# 低耦合:不要让你的代码根某种东西紧紧的绑定在一起
# high cohesion low coupling
#通过向函数中传入函数,可以写出更通用的代码
#calc函数中的第二个函数是另一个函数,它代表了一个二元函数
#这样calc函数就不需要根某一种特定的二元运算耦合在一起```
def calc(my_list, op):
    total = my_list[0]
    for index in range(1, len(my_list)):
        total += my_list[index]
    return total

def add(x, y):
    return x + y

def mul(x, y):
    return x * y

def main():
    my_list = [2, 3, 4, 5, 6]
    print(calc(my_list, add))

if __name__ == '__main__':
    main()

实例

from abc import abstractmethod# abc模块中还有一个包装器abstractmethod
# 通过这个包装器可以将方法包装为抽象方法 必须要求子类进行重写
class Employee(object):
    def __init__(self, name):
        self._name = name

    @property
    def name(self):
        return self._name

    @abstractmethod
    def get_salary(self):
        pass

class Manager(Employee):
    def get_salary(self):
        return 15000.0

class Programmer(Employee):
    def __init__(self, name):
        super().__init__(name)  # 继承父类的方法
        self._working_hour = 0

    @property  #包装器,装饰器
    def working_hour(self):
        return self._working_hour

    @working_hour.setter  #修改器
    def working_hour(self, working_hour):
        self._working_hour = working_hour if working_hour > 0 else 0

    def get_salary(self):
        return 150.0 * self._working_hour


class Salesman(Employee):
    def __init__(self, name):
        super().__init__(name)
        self._sales = 0

    @property
    def sales(self):
        return self._sales

    @sales.setter
    def sales(self, sales):
        self._sales = self._sales if sales > 0 else 0

    def get_salary(self):
        return 1200 + self._sales * 0.05

def main():
    emps = [
        Manager('张三'), Programmer('李四'), Salesman('王五')
    ]
    for emp in emps:
        if isinstance(emp, Programmer):#是不是某种类型的实例
            emp.working_hour = int(input('请输入%s的工作时间' % emp.name)) # 在这里使用修改器修改了父类的方法
        if isinstance(emp, Salesman):
            emp.sales = int(input('请输入%s的销售额' % emp.name))
#同样是调用get_salary的方法,但是不同的员工表现出了不同的行为
        # 因为三个子类都重写了get_salary方法,所以,此处有多态行为 ***********
        print('%s的工资为%.2f' % (emp.name, emp.get_salary()))

if __name__ == '__main__':
    main()
上一篇 下一篇

猜你喜欢

热点阅读