Python集合和函数

深浅拷贝:
.copy()方法,浅拷贝值拷贝一层。
列表中的列表和字典会深拷贝,其他类型会浅拷贝。
列表中的列表和字典会随着副本的修改而改变,其他类型不会随着副本的改变为改变。
a=b不是复制,是两个变量共享同一内存空间,一个改变另一个也改变。
a=[[1,2],3,4] b=copy.copy(a):浅拷贝,c=copy.deepcopy(a):深拷贝

集合:(重点)
作用:把不同的元素集合在一起,去除重复的内容,是无序的,集合里的元素是可哈希的。
set是可变集合,本身是非可哈希的,不能作为字典的键,
frozenset不可变集合。

集合创建:
s=set('alex li')

访问集合:
由于集合本身是无序的,所以不能为集合创建索引或切片操作,只能循环遍历或使用in、not in来访问或判断集合元素。
for i in s:
print(i)


集合操作:
s.add('uu'):添加一个元素
s.update('ops'):当成多个元素添加
s.remove():删除元素
s.pop():随机删除
s.clear():清空集合
del s:删除集合

集合操作符:
intersection():交集 {&}
union():并集 {|}
difference():差集 {-}
symmetric_difference()对称差集,反向交集 {^}
a.issuperset(b):a>b 父集
a.issubset(b):a<b 子集

函数:
作用:减少重复代码;方便修改,更易扩展;保持代码一致性

函数创建:define定义
def 函数名称():
函数代码

函数命名规则:
--函数名必须以下划线或字母开头,可以包含任意字母、数字或下划线的组合。不能使用任何的标点符号;
--函数名是区分大小写的。
--函数名不能是保留字。

函数调用一定要加括号。

函数参数:
----必需的参数:

必需参数须以正确的顺序传入函数。调用时的数量必须和声明时的一样。
def f(name,age):

print('I am %s,I am %d'%(name,age))

f('alex',18)
f('alvin',16)

----关键字参数:

关键字参数和函数调用关系紧密,函数调用使用关键字参数来确定传入的参数值。使用关键字参数允许函数调用时参数的顺序与声明时不一致,因为 Python 解释器能够用参数名匹配参数值。
def f(name,age):

print('I am %s,I am %d'%(name,age))

# f(16,'alvin') #报错
f(age=16,name='alvin')

----缺省参数(默认参数):默认参数要跟在其他参数后面

调用函数时,缺省参数的值如果没有传入,则被认为是默认值。下例会打印默认的age,如果age没有被传入:
def print_info(name,age,sex='male'):

print('Name:%s'%name)
print('age:%s'%age)
print('Sex:%s'%sex)
return

print_info('alex',18)
print_info('铁锤',40,'female')

----不定长参数

你可能需要一个函数能处理比当初声明时更多的参数。这些参数叫做不定长参数,和上述2种参数不同,声明时不会命名。
加了星号(*)的变量名会存放所有未命名的变量参数。而加(**)的变量名会存放命名的变量参数

不定长参数的位置:
*args无命名参数要放在命名参数的左边;**kargs参数放在右边;默认参数,放最左边

def print_info(*args,**kwargs):
print(args)

#for i in kwargs:
# print('%s:%s'%(i,kwargs[i]))
print(kwargs)
for i in kwargs:
print('%s:%s'%(i,kwargs[i]))

print_info('j','hj',[1,2,3],name='alex',age=12,job='it',hobby='grils')

函数返回值:

return None:默认
return作用:结束函数;返回某个对象
注意:函数没有写return,默认返回None;如果return多个对象,那么会把多个对象封装成一个元祖返回。

=============================================================================
作用域(重要):L(local) E(enclosing) G(global) B(built_in)
局部作用域不能修改全局作用域。
count=10
def outer():
print(count)
count=5
会出错

局部变量要修改全局变量要加关键字global
count=10
def outer():
global count
print(count)
count=5
print(count)

local作用域要想修改enclosing作用域必须加上nonlocal count
def outer():
count=10
def inner():
nonlocal count
count=20
print(count)
inner()
print(count)
outer()

LEGB
x = int(2.9) # int built-in

g_count = 0 # global
def outer():
o_count = 1 # enclosing
def inner():
i_count = 2 # local
print(o_count)
# print(i_count) 找不到
inner()
outer()

# print(o_count) #找不到
小结:
1、变量查找顺序:LEGB,作用域局部>外层作用域>当前模块中的作用域>Python内置作用域;
2、只有模块、类及函数才能引入新的作用域;
3、对于一个变量,内部作用域先声明就会覆盖外部变量,不声明直接使用,就会使用外部作用域的变量;
4、内部作用域要修改外部作用域变量时,全局变量要使用global关键字,嵌套作用域变量要使用nonlocal关键字,nonlocal是Python3新增的关键字,有了这个关键字,就能完美的实现闭包了

高阶函数:
函数名可以进行赋值,函数名可以作为参数,还可以函数的返回值
def f(n):
return n*n
print(f(4))

def foo(a,b,func):
return func(a)+func(b)

print(foo(1,2,f))
结果:5
====================
def f():
print('ok')

def bar(a,b,func):
func()
return 1
print(bar(1,2,f))
结果:
ok
1
==================
def foo3():
def inner():
return 8
return inner

foo3()
print(foo3())#返回inner的内存地址
print(foo3()())#返回8

递归函数:
特点:调用自身函数;有一个结束条件
能用递归写的程序循环都可以解决,递归效率在很多时候非常低,不推荐使用

阶乘:
def f(n):
if n==1:
return 1
return n*f(n-1)
print(f(4))

斐波那契数列:

def fibo(n):

before=0
after=1
for i in range(n-1):
ret=before+after
before=after
after=ret

return ret

print(fibo(3))

#**************递归*********************
def fibo_new(n):#n可以为零,数列有[0]

if n <= 1:
return n
return(fibo_new(n-1) + fibo_new(n-2))

print(fibo_new(3))
print(fibo_new(30000))#maximum recursion depth exceeded in comparison

内置函数:

(1)filter:过滤器掉相同的字符
str=['a','b','c','d']
def fun1(s):
if s!='a':
return s
ret=filter(fun1,str)
print(ret) #<filter object at 0x000001A0AF55B940>
print(list(ret)) #['b','c','d']
结果为迭代器(过滤器)对象

(2)map:
str = ['d','a', 'b']
def fun2(s):
return s + "alvin"
ret = map(fun2, str)
print(ret) #<map object at 0x000001D4F52972B0> map object迭代器
print(list(ret)) #['dalvin', 'aalvin', 'balvin']

(3)reduce:叠加
from functools import reduce #Python3使用reduce要加这句话
def add1(x,y):
return x + y
print (reduce(add1, range(1, 10)))## 4950 (注:1+2+...+99)
print (reduce(add1, range(1, 101), 20))

#阶乘
def mul(x,y):
return x*y
print(reduce(mul,range(1,10)))

(4)lambda:
def add(a,b):
return a + b
print add(2,3)

#匿名函数
add = lambda a,b : a + b
print(add(2,3))

原文地址:https://www.cnblogs.com/cxli99/p/8448535.html