Python第三天
一、杂项
1、通过eval()自动转化input结果:如数字、列表、字符串
2、print(value,,,seq=' ',end='',file='') seq是每个value间的值;end是结束符 ;file是输出位置,默认是sys.stdout
fp=open("a.txt'',"a+")
print("zzzz",file=fp)
3、sys.stdin.read()或者是readline()都是从缓冲区读取数据,参数中的数字表示一下读取多少个;readline是\n结尾
二、列表
1、lst.index(x) 返回列表lst第一个值为x的索引,若不存在,则抛出异常
因此需要先判断x in lst
2、lst.remove(x)删除首次出现x的指定位置
3、lst.count(x)返回x的个数,可以与2连用,删除所有x
4、lst.pop([index]) 默认是-1
5、lst.insert(index,x)在索引为index的位置插入x
6、lst.append(x)追加元素
7、lst.extend(L) =lst+L
8、x.sort(key=lambda item:len(str(item)) , reverse=True) //按字符串长度比较排序
True为升序
9、sort和reverse都是原地排序,使用之后值会改变
而sorted()和reversed()都会生成一个新列表,值不会发生改变
sort()和reverse()都是类方法
但是sorted()和reversed()都是内置函数,只能这么用sorted(x)
10、max() min() 也是内置函数
因此 max(x,key=str) 通过字符比较来选取最大值
11、zip()内置函数:用于将多个列表中的元素重新组合成元组,并返回包含这些元组zip对象
list(zip( [1,2,3,4,5,6] , [7,7,7,9,6,4,3,2,2] )) //一一对应,以短的为准
12、enumerate(x) 返回的是元组集合,每个元组有(index,value)组成
三、lambda表达式
1、lambda用来声明匿名函数,也可以给他赋函数名
g=lambda x,y,z=3:x+y+z 参数是x,y,z,z的默认值是3,返回值是x+y+z
2、x.sort(key=lambda item : len(str(item)) , reverse=True) //按字符串长度比较排序
3、在python,你甚至可以使用字典来使用lambda
D={'f1':(lambda :5),'f2':(lambda x:x+2) ,'f3':(lambda x,y:x*y)}
调用方式:
D['f1']()+D['f2'](2)+D['f3'](5,7)