python之有参装饰器和迭代器用法

 

1.有参装饰器:是无参装饰器的加强版

                    在无参装饰器上面再包个函数(相当于多增加一个值)    

                    无参装饰器函例图:

 

                    

def check(func):       # index()运行的先运行@check=check(index)把index内存地址赋值给func 得到check_user内存地址返回值并赋值新的index变量名
    def check_user(*args, **kwargs):
        while True:
            user_info = input("请输入用户名:").strip()
            pwd_info = input('请输入密码:').strip()
            if user_info == name and pwd_info == pwd:
                print("loging successfull")
            else:
                print('用户名和密码错误')
                continue
            res = func(*args, **kwargs)
            return res

    return check_user


@check
def index():      # 运行@check(index) func内存地址=index赋值 返回check_user内存地址 在重新赋值一个新的index=check_info实际上内存地址已经更换了
                   # 最后直接调用index()指向的是check_info()的内存地址
    print('welcome to index')
    time.sleep(2)
    return 123

 

import time

current_user={'user':None}

def deco(func):
    def wrapper(*args,**kwargs):
        if current_user['user']:
            #已经登陆过
            res = func(*args, **kwargs)
            return res
        user=input('username>>: ').strip()
        pwd=input('password>>: ').strip()
        if user == 'egon' and pwd == '123':
            print('login successful')
            # 记录用户登陆状态
            current_user['user']=user
            res=func(*args,**kwargs)
            return res
        else:
            print('user or password error')
    return wrapper

@deco
def index():
    print('welcome to index page')
    time.sleep(1)

@deco
def home(name):
    print('welecome %s to home page' %name)
    time.sleep(0.5)


index()
home('egon')
'''

 

  有参可以增加认证来源的判断,根据传入的参数进行多种分类比如如下多种登录认证

 

            

import time
current_user={'user':None}
def auth(engine='file'):
    def deco(func):
        def wrapper(*args,**kwargs):
            if current_user['user']:
                #已经登陆过
                res = func(*args, **kwargs)
                return res
            user=input('username>>: ').strip()
            pwd=input('password>>: ').strip()
            if engine == 'file':
                # 基于文件的认证
                if user == 'egon' and pwd == '123':
                    print('login successful')
                    # 记录用户登陆状态
                    current_user['user']=user
                    res=func(*args,**kwargs)
                    return res
                else:
                    print('user or password error')
            elif engine == 'mysql':
                print('基于mysql的认证')
            elif engine == 'ldap':
                print('基于ldap的认证')
            else:
                print('无法识别认证来源')
        return wrapper
    return deco

@auth(engine='mysql') # @deco #index=deco(index) #index=wrapper
def index():
    print('welcome to index page')
    time.sleep(1)

@auth(engine='mysql')
def home(name):
    print('welecome %s to home page' %name)
    time.sleep(0.5)


index()

 

 

 

2.什么是迭代器

    1.迭代器即迭代取值的工具

    2.迭代就是一个重复的过程,每一次都要重复是基于上次的结果而来

    单纯的重复并不是迭代

    迭代:

    l=['a','b','c']

    def iterator(item):

        i=0

        while i <len(itme):

                print(l[i])

                i+=1            

2.为什么要有迭代器

    基于索引的迭代器取值方式只适用于列表、元组、字符串

    对于没有索引的字典、集合、文件、则不适合

    所以必须找到一种通用的并且不依赖索引的迭代器取值方式=》迭代器 

    迭代器适用于可迭代的类型

3.如何用迭代器

   s='hello'

def iterator(item):

        i=0

        while i <len(item):

                print (item[i])

                i+=1

iterator(s)

 

    可迭代对象:在python中但凡内置有—iter—方法的对象都是可迭代对象

                            (字符串,列表,元组,字典,集合,文件都是可迭代的对象)

                                迭代器对象=可迭代的对象——iter——()

      迭代器对象:即内置有——iter——方法,有内置有—next——方法的对象

                            迭代器对象本身=迭代器对象——iter——()

                            拿到的是下一个值=迭代器对象——next——()

                        ##执行可迭代对象的——iter——方法得到的就是内置的迭代器对象

                         ###文件对象本身就是迭代器对象

                    强调:

                        迭代器对象一定是可迭代的对象,反之则不让

                        一旦迭代器取取值干净,在继续取就会抛出stopiteration

                        迭代器对象:指的是既内置有——iter——方法,又内置有——next——方法的对象

                                           执行迭代器对象的——next——得到的是迭代器下一个值

                                           执行迭代器对象的——iter——得到的仍然是迭代器本身

                        实例:

                            

for循环:迭代器循环

    info={‘name’:'egon','agon':18}

 #in后面跟的一定要是可迭代的对象

    for k in info:    #info_iter=info._iter_()   for循环底层原理就是用迭代器方式定义 (检测运行完毕后自动结束)

            print(k)       

 

 

while循环需要定义一个检测机制,运行完毕后才不会报错           

总结迭代器对象的优缺点:

    指的是既内置有——iter方法:

        优点:提供一种通用的、可以不依赖索引的迭代取值方式

          2.迭代器对象更加节省内存     (比如读取大文件时候,读一行就取一行)

            

        缺点:

            1.迭代器的取值不按照索引的方式更灵活,因为他只能往后不能往前退

            2.无法预测迭代器值的个数

            比如:

 

posted @ 2018-06-13 00:03  Marcki  阅读(131)  评论(0编辑  收藏  举报