生成器:就是一种自定义的迭代器
自定义迭代器的好处:节省内存
return只能返回一次值,函数就立即结束了
‘’’
def func():
print(‘1111111’)
print(‘1111111’)
print(‘1111111’)
print(‘1111111’)
yield 1,2
print(‘22222122222’)
yield
print(‘333333333333’)
yield
print(‘44444444444’)
# 如何得到生成器(自定义的迭代器):
# 函数内但凡存在yield关键字,调用函数不会执行函数体代码,会得到一个返回值,该返回值就是我们自定义的生成器
g = func()
#print(g)
#g.__iter__()
#g.__next__()
res1 = next(g)
#print(res1)
res2 = next(g)
#print(res3)
next(g)
‘’’
1、列表生成式
l=[]
for i in range(11):
if i > 3:
l.append(“x”)
2、字典生成式
dic = {“name”: “egon”, “age”: 18, “gender”: “male”, “level”: 10}
new_dic = {k.upper(): v for k, v in dic.items() if k != “level”}
new_dic = {k+"_": str(v) for k, v in dic.items() if k != “level”}
print(new_dic)
3、集合生成式
s = {i for i in “hello” if i != “l”}
print(s)
4、生成器表达式
res = (i for i in range(5))
print(res)
1、编程思想就是编写程序的套路,与具体的技术点无关
2、面向过程
核心是过程二字,过程就是解决问题的步骤,即先干啥、再干啥、后干啥
基于面向过程编程就好比在设计一条条的流水线
优点:将复杂的问题流程化、进而简单化
缺点:所有环节耦合到一起,环环相扣,如果要修改某个环境,有可能会牵一发而动全身,扩展性差
三元表达式(替代if else语法)
def max2(x,y):
if x > y:
return x
else:
return y
内置函数
res=abs(-1) 取绝对值
print(all([1,2,True]))
将一个可迭代对象里面所有的元素判断是否为真,如果全部为真的话就返回真,如果有一个是假,那么就是假,如果没有值的话就返回真
print(any([1,2,None])) 将一个可迭代对象里面所有的元素判断是否为真,如果全部为假的话就返回假,如果有一个是真,那么就是真,如果没有值的话就返回假
bin() 转成二进制
bytes() 转成字节类型
callable() 判断能否调用
chr() 参照ASCII表根据给到的数字,返回是什么字符
ord() 参照ASCII表,根据给到的字符,返回对应的数字
classmethod
staticmethod
property
面向对象里讲
print(divmod(10,3) ) 得到10 / 3 的商和余数
lst2=list(enumerate(lst1))
print(lst2)
得到可迭代对象的索引/编号和值
for i,item in enumerate(lst):
print(i,item)