初识Python之面向对象篇(下)

前面我们介绍了关于Python面向对象的基础知识和概念,今天我们来了解一下关于它的高级用法与进阶。

模块架构,早在之前的文章我们就已经提到过,但是在这里我又不得不提起,因为它是面向对象的一个接口,我们只有熟练这些模块的使用,才能对后面的一些知识点得心应手。

'''模块架构'''
import math
from math import sqrt
import math as shuxue
a=math.sqrt(16)         #直接用模块加函数
b=sqrt(4)               #用函数
c=shuxue.sqrt(9)        #用自命名的模块加函数
print(a,"\t",b,"\t",c)

if __name__=="__main__":
    print(a)
else:
    print(c)

在这里插入图片描述

"""使用包"""
'''例如上述实验方法,我们在导入包的时候,可以有不同的方法,因为导入不同,所以调用也不同
所以,我们在调用的时候必须要看后面的是什么,比如import requests 这个时候我们要使用这个里面的功能
必须以 requests.get()方法,或者from requests import get方法,还有一系列的,所以我们在自己开发试验的时候必须
熟悉自己的方法,避免混淆
'''

'''导入类'''
'''类的导入与模块相似'''
'''迭代器'''
'''迭代器的使用例如for循环语句遍历迭代器'''

class Use:
    def __init__(self,x=2,max=50):
        self.__mul,self.__x=x,x     #初始化属性,X的初始值是2
        self.__max=max
    def __iter__(self):
        return self
    def __next__(self):
        if self.__x and self.__x !=1:
            self.__mul *=self.__max
            if self.__mul <=self.__max:
                return self.__mul
            else:
                raise StopIteration
if __name__=="__main__":
    my=Use()
    for i in my:
        print("迭代数据元素为:",i)


'''使用内置迭代器方法iter()'''
class Counter:
    def __init__(self,x=0):
        self.x=x
counter=Counter()
def used_iter():
    counter.x+=2
    return counter.x
for i in iter(used_iter,52):    #iter该函数用于函数,当最后一个参数迭代后返回和自己定义的相等的时候,程序结束,例如12
    print(i)

from itertools import *
def height_class(h):
    if h > 180:
        return 'tall'
    elif h < 180:
        return "short"
    else:
        return "middle"
friends=[191,158,159,169,148,163,175,156,123,149,256,596,648,789,156,3589,180]
friends=sorted(friends,key=height_class)
for m,n in groupby(friends,key=height_class):#使用groupby()遍历数据
    print(m)
    print(list(n))

在这里插入图片描述

'''生成器'''
def fib(max):
    a,b=1,1
    while a <max:
        yield a
        a,b=b,a+b
for n in fib(15):
    print(n)

def xie():
    print("等待接收任务......")
    while True:
        data=(yield )
        print("收到任务:",data)
def producer():
    c=xie()
    c.__next__()
    for i in range(5):
        print("发送一个任务......","任务%d"%i)
        c.send("任务%d"%i)
if __name__=="__main__":
    producer()

在这里插入图片描述

'''装饰器'''
'''装饰器可以解决我们在实际开发当中,减轻我们代码的重复率,提高效率'''
def window(run):
    def wrapper(*args,**bian):#定义了一个包装器函数
        print("植入木马中......")
        run(*args,**bian)
        print("木马已经渗入......")
    return wrapper
@window
def worm(x):
    a=[]
    for i in range(x):
        a.append(i)
    print(a)
@window
def str(name):
    print("hello",name)
if __name__=="__main__":
    worm(10)
    print()
    str("h7n9病毒")

在这里插入图片描述

def deco(func):
    def _deco(a,b):
        print("在函数myfunc()之前被调用。")
        ret=func(a,b)#这里必须要将装饰器里面的参数实例化,不然不会产生效益
        print("在函数myfunc()之前被调用,结果是:%s"%ret)
        return ret
    return _deco
@deco
def myfunc(a,b):
    print("函数myfunc(%s,%s)被调用!"%(a,b))
    return a+b
myfunc(4,2)
myfunc(10,16)

在这里插入图片描述

# 使用装饰器装饰类
def zz(myclass):
    class InnerClass:
        def __init__(self,z=0):
            self.z=z
            self.wrapper=myclass()
        def position(self):
            self.wrapper.position()
            print('z轴坐标:',self.z)
    return InnerClass
@zz
class coordination:
    def __init__(self,x=0,y=0):
        self.x=x
        self.y=y
    def position(self):
        print("x轴坐标:",self.x)
        print("y轴坐标:",self.y)
if __name__=="__main__":
    coor=coordination()
    coor.position()

在这里插入图片描述

'''命名空间'''
'''涉及到全局变量和局部变量,这里必须要明确两个访问函数
local()可以访问局部命名空间
globals()函数可以访问全局变量
'''
def func(i,str):
    x=123321
    print(locals())
func(1,"wangxiaowang")#包括了调用函数的复杂语法书写,简化了代码

在这里插入图片描述

'''闭包'''
def func(name):
    def inner_func(age):
        print("name",name,"\t","age",age)
    return inner_func
bb=func("笑傲江湖")#调用func的时候就开始产生了一个闭包inner_func,里面有自己的name,就算函数执行完后,name依然会存在的
bb(19)

def delay_fun(x,y):
    def caculator():#使用嵌套函数,实现延迟求和功能
        return x+y
    return caculator
if __name__=="__main__":
    print("返回一个可以求和的函数,但是不去求和!")
    msum=delay_fun(3,4)
    print()
    print("返回一个计算值!")
    print(msum())

在这里插入图片描述


'''装饰器与闭包'''
def deco(func):
    def _deco():
        print("函数闭包实现......")
        func()#这里才是调用了,所以此函数中只有该函数是实例化了,里面的闭包其实没有调用和打印
        print("函数闭包实现中......")
    return _deco#只是返回了它的值,并没有调用
@deco#f=deco(f)
def f():
    print("使用装饰器实现中......")
if __name__=="__main__":
    f()#知道第二次才返回_deco的值,也就是打印了,这个就是闭包的神奇之处。

在这里插入图片描述

'''使用闭包定义泛型函数'''

def fan(a,b):
    def afan(x):
        return a* x+b
    return afan
if __name__=="__main__":
    fan23=fan(2,3)
    fan25=fan(2,5)
    print("调用函数实现:",fan23(4))
    print("调用函数熟悉:",fan25(6))

在这里插入图片描述
总结

学完Python的面向对象之后,我们发现它其实也不是想象中的那么难,我们要知道Java的基础语言就是基于类的叠加,所以大家学习Python还是要把基础打牢,这样才能真正的学以致用。后期我也会推出《初识Java之系列篇章》希望有兴趣的小伙伴继续关注小王,我们一起“快乐代码,精彩人生”。

后期我将继续推出Python编程的一些语法,比如文件操作,异常处理,多线程开发等,同时我也会设置一个专栏《初识爬虫之系列篇章》,到时候有兴趣的小伙伴,可以来看看。

好的,本期文章我们就到这里了,我们下期文章再会!

猜你喜欢

转载自blog.csdn.net/weixin_47723732/article/details/107761311