[Python学习笔记][第五章Python函数设计与使用]

2016/1/29学习内容

第四章 Python函数设计与使用

以前的几页忘记保存了 很伤心python

变量做用域

-一个变量已在函数外定义,若是在函数内须要修改这个变量的值,并将这个赋值结果反映到函数以外,能够在函数内用global声明这个变量为全局变量,明确声明要使用已定义的同名全局变量markdown

-在函数内部直接使用global关键词将一个变量声明为全局变量,即便在函数外没有定义该全局变量,在调用这个函数以后,将自动增长新的全局变量dom

def demo():
    global a;
    a=3;
    demo();
    print(a)

#函数

也能够这么理解:在函数内若是只引用某个变量的值而没有为其赋新值,该变量为(隐式的)全局变量,若是在变量内任意位置有为变量赋新值的操做,该变量即被认为(隐式的)局部变量,除非使用关键词global进行声明。学习

还有这种先斩后奏的用法

>设计

a=10;
def demo():
    a=666  
    print(a)
    global a;
demo();
print(a)

实际工程中若是须要在同一个程序的不一样模块之间共享全局变量的话,能够编写一个专门的模块来实现这一目的code

lambda表达式

labmda表达式能够用来声明匿名函数,即没有函数名字的临时使用的小函数对象

重要用法…..sorted中作key

f=lambda x,y,z: x+y+z;
print(f(1,2,3))
#6
g=lambda x,y=2,z=3:x+y+z #含有默认值参数
print(g(1))
#6
print(g(x=2,z=4,y=6))   #关键参数
#12
#归根到底函数也是一种变量
#因此lambda 和 普通函数均可以放到 list 中
#lambda 也能调用其余函数
L=[lambda x : x**2,lambda x : x**3]
import random
data=[1,2,10,100,1000,10000];
random.shuffle(data)
print(data)
#[10, 10000, 1000, 1, 2, 100]
data.sort(key=lambda x:x)
print(data)
#[1, 2, 10, 100, 1000, 10000]
data.sort(key=lambda x:-x)
print(data)
#[10000, 1000, 100, 10, 2, 1]
def demo(x):
    return x
data.sort(key=demo)     #既然lambda算子能够,那么函数也能够,道理上二者等价 果真
print(data)
#[1, 2, 10, 100, 1000, 10000]

函数高级用法

map(),reduce(),filter()

详情已经了解不少了作用域

用yield语句的函数来建立生成器

def f():
    a,b=1,1
    while True:
        yield a
        a , b = b,a+b;
a=f()
for i in range(10):
    print(a.__next__(),end= ' ' )
#1 1 2 3 5 8 13 21 34 55
print()
a=f()
for i in f():
    if i > 1000:
        break;
    else :
        print(i,end=' ')
#1 1 2 3 5 8 13 21 34 55 89 144 233 377 610 987

使用dis模块的功能能够查看函数的字节码指令

函数嵌套定义与可调用对象

在Python中,函数时能够嵌套定义的。另外,任何包含call()方法的类的对象都是能够调用的.it

def linear(a,b):
    def result(x):
        return  a*x+b
    return result
a=linear(1,2)
print(a(2))
#4

class linear2:
    def __init__(self,a,b):
        self.a,self.b=a,b
    def __call__(self,x):
        return self.a*x+self.b
taxes=linear2(0.3,2)
print(taxes(5))
#3.5
相关文章
相关标签/搜索