生成器 和推导列表定义类似,但是使用()定义,而不是使用[] 使用方式1:用括号定义 next(g)访问元素
g = (x*x for x in range(10))
next(g)
next(g) 1
next(g) 4
next(g) 9
next(g) 16
next(g) 25
next(g) 36
next(g) 49
next(g) 64
next(g) 81
next(g) Traceback (most recent call last): File "<stdin>", line 1, in <module> StopIteration
遍历生成器
g = (x**2 for x in range(5)) for v in g: ... print(v) ... 01 4 9 16
习题3:用生成器生成10以内的奇数
g = (x for x in range(1,10,2)) for n in g: ... print(n) ... 1 3 5 7 9
使用方式2:用yield定义
def odd(): print ('step 1') yield 1 print ('step 2') yield 3 print ('step 3') yield 5 o = odd() print (next(o)) print (next(o)) print (next(o)) print (next(o))
#for i in o:
print i
def g(): print("a") yield 1 print("b") yield 2 print("c") yield 3 print("d")
g = g() for i in g: print(i)
深、浅拷贝
import copy lst_1 = [1,2,3,["a","b"]] lst_2 = copy.copy(lst_1) lst_3 = copy.deepcopy(lst_1)
lst_1.append(4) lst_1[3].append("c")
print(lst_1) print(lst_2) print(lst_3)
直接赋值、浅拷贝和深度拷贝解析 直接赋值:其实就是对象的引用(别名)。 浅拷贝(copy):拷贝父对象,不会拷贝对象的内部的子对象。 深拷贝(deepcopy): copy 模块的 deepcopy 方法,完全拷贝了父对象及其子对象。 字典浅拷贝实例 实例1:
a = {1: [1,2,3]} b = a.copy() a, b ({1: [1, 2, 3]}, {1: [1, 2, 3]})
a[1].append(4) a, b ({1: [1, 2, 3, 4]}, {1: [1, 2, 3, 4]}) 深度拷贝需要引入 copy 模块:
实例
import copy c = copy.deepcopy(a) a, c ({1: [1, 2, 3, 4]}, {1: [1, 2, 3, 4]})
a[1].append(5) a, c ({1: [1, 2, 3, 4, 5]}, {1: [1, 2, 3, 4]}) 解析 1、b = a: 赋值引用,a 和 b 都指向同一个对象。
2、b = a.copy(): 浅拷贝, a 和 b 是一个独立的对象,但他们的子对象还是指向统一对象(是引用)。
3、b = copy.deepcopy(a): 深度拷贝, a 和 b 完全拷贝了父对象及其子对象,两者是完全独立的。
实例2: 列表的深浅拷贝 以下实例是使用 copy 模块的 copy.copy( 浅拷贝 )和(copy.deepcopy ):
实例
#!/usr/bin/python # -*-coding:utf-8 -*- import copy
a = [1, 2, 3, 4, ['a', 'b']] #原始对象
b = a #赋值,传对象的引用
c = copy.copy(a) #对象拷贝,浅拷贝
d = copy.deepcopy(a) #对象拷贝,深拷贝
a.append(5) #修改对象a
a[4].append('c') #修改对象a中的['a', 'b']数组对象
print( 'a = ', a )
print( 'b = ', b )
print( 'c = ', c )
print( 'd = ', d )
以上实例执行输出结果为:
('a = ', [1, 2, 3, 4, ['a', 'b', 'c'], 5])
('b = ', [1, 2, 3, 4, ['a', 'b', 'c'], 5])#因为b和a指向同一个内存地址,是同一个对象,对a的任何改动都会影响到b
('c = ', [1, 2, 3, 4, ['a', 'b', 'c']])#c是浅拷贝,只影响对子对象元素的修改,其他元素是独立的
('d = ', [1, 2, 3, 4, ['a', 'b']])#每个元素都是独立的,修改互不影响
通过list实现一个简单的堆栈
#encoding=utf-8
stack_list = []
stack_list.append(1)
print(stack_list)
stack_list.append(2)
print(stack_list)
stack_list.append(3)
print(stack_list)
print(stack_list)
print(stack_list.pop())
print(stack_list)
print(stack_list.pop())
print(stack_list)
print(stack_list.pop())
print('*'*30)
for i in range(1,6):
stack_list.append(i)
print(stack_list)
for i in range(5):
stack_list.pop()
print(stack_list)
通过list实现一个简单的队列
#encoding=utf-8
stack_list = []
for i in range(5):
stack_list.append(i)
print(stack_list)
for j in range(5):
print(stack_list)
print(stack_list.pop(0))
from collections import deque
queue = deque([1,2,3,4,5,6])
queue.append(7)
queue.append(8)
print(queue.popleft())
print(queue.popleft())
print(queue)
元组 元素只能访问其元素,不能进行修改、删除,适用元素固定的情况
创建元组 创建空元组
t = ()
创建只有一个元素的元组
t = (1,)
t = 2,3 t (2, 3) 访问元组元素 元组属于序列,可通过下标访问元素
t = (1,2,3,4,5) t[0] 1
t[3] 4
通过切片访问元组
t[:] (1, 2, 3, 4, 5)
t[-1] 5
t[:3] (1, 2, 3)
t[:3:2] (1, 3)
t[::-1] (5, 4, 3, 2, 1)
t[-3:-1:-1] ()
t[-3:-1:1] (3, 4)
倒序start 要大于end
t[-1:-3:-1] (5, 4)
t[-1:-4:-1] (5, 4, 3)
t (1, 2, 3, 4, 5)
for i in range(len(t)-1,-1,-1):#倒序遍历start要大于end,因为要全部取end =-1 ... print(t[i]) ... 5 4 3 2 1
连接元组 +
t (1, 2, 3, 4, 5)
t2 = ("a","b") t + t2 (1, 2, 3, 4, 5, 'a', 'b')
复制元组 *
t2 * 3 ('a', 'b', 'a', 'b', 'a', 'b')
查看元组类型
type(t) <class 'tuple'>
元组赋值给变量
a,b = ("name","sex") a 'name'
b 'sex'
a,b = 3,4 a 3
b 4
函数返回元组
def fun(a,b): ... return a,b ...
s = fun(2,3) print(s) (2, 3)
tuple()工厂函数 转换元组
列表转元组
tuple([1,2,3]) (1, 2, 3)
字符串转元组
tuple("abc") ('a', 'b', 'c')
字典转元组,只转key
tuple({1:2,3:4}) (1, 3)
t = [1,2,3,4,5,6] len()
len(t) 6 min()
min(t) 1 max()
max(t) 6