内置函数(二)

1.4.2和数据结构相关(24)

  列表和元祖(2)

list:将一个可迭代对象转化成列表(如果是字典,默认将key作为列表的元素)。
1 dic ={1:2,3:4}
2 print(list(dic))
tuple:将一个可迭代对象转化成元祖(如果是字典,默认将key作为元祖的元素)
字典转换成元祖
1 dic1={'a':2,3:4}
2 tu1=tuple(dic1)
3 print(tu1)
4 dic2 = dict([tu1])
5 print(dic2)
字符串转换成元祖
1 str1 ='abcd123'
2 tup2 =tuple(str1)
3 print(tup2)
列表转换成元祖
1 lis1 = [1,2,3,4]
2 tup3 = tuple(lis1)
3 print(tup3)
reversed:将一个序列翻转,并返回此翻转序列的迭代器。
字符串的翻转
1 str = 'abcdefg'
2 print(reversed(str))    #<reversed object at 0x0000018530CF9E48>
3 print(list(reversed(str)))  #['g', 'f', 'e', 'd', 'c', 'b', 'a']
列表的转换
1 lis = [1,2,3,4,5,6]
2 reversed(lis)
3 print(list(reversed(lis)))
字典的转换(字典不支持翻转)
1 dic ={1:2,3:4,5:6}
2 print(list(reversed(dic)))  #TypeError: 'dict' object is not reversible
集合的转换(集合不支持翻转)
 1 set1 ={1,2,3,4}
 2 reversed(set1)  #TypeError: 'set' object is not reversible
 slice:构造一个切片对象,用于列表的切片。
1  lis = [1,2,3,4,5,6]   #列表切片
2  l1 =slice(0,6,3)
3  print(lis[l1])
4  str ='abcdefghi'  #字符串切片
5 sl=slice(0,len(str),2)
6 print(str[sl])
format:与具体数据相关,用于计算各种小数,精算等。
1 print(format('test',"<20"))     #一行20个字符test左对齐
2 print(format('test',">20"))      #一行20个字符test左对齐
3 print(format('test',"^20"))      #一行20个字符test居中对齐
bytes:unicode ---> bytes 类型  ****
 1 a1 = '太白'
 2 # print(a1.encode('utf-8'))
 3 print(a1.encode('utf-8').decode())
 4 
 5 bytes:unicode ---> bytes 类型
 6 a1 = '太白'
 7 b1 = bytes(a1,encoding='utf-8')
 8 print(b1)
 9 
10 a1 = -100
11 b1 = -100
12 print(id(a1))
13 print(id(b1))
bytearry:返回一个新字节数组。这个数组里的元素是可变的,并且每个元素的值范围: 0 <= x < 256。
1 ret = bytearray('alex',encoding='utf-8')
2 print(id(ret))
3 print(ret)  # bytearray(b'alex')
4 print(ret[0])  # 97
5 ret[0] = 65
6 print(ret)  # bytearray(b'Alex')
7 print(id(ret))
memoryview
1 ret = memoryview(bytes('你好',encoding='utf-8'))
2 print(len(ret))  # 6
3 print(ret)  # <memory at 0x000001D3D6FCD048>  # [\xe4,\xbd,\xa0,\xe5,\xa5,\xbd]
4 print(bytes(ret[:3]).decode('utf-8'))  #
5 print(bytes(ret[3:]).decode('utf-8'))  #
ord:输入字符找该字符编码 unicode  的位置  **
1 print(ord('a'))
2 print(ord(''))
chr:输入位置数字找出其对应的字符 unicode **
1 print(chr(97))
2 print(chr(20013))
3 ascii:是ascii码中的返回该值,不是则返回他在unicode的位置(16进制。) **
4 print(ascii('a'))
5 print(ascii(''))  # '\u4e2d'
repr:返回一个对象的string形式(原形毕露)
1 a = '孙飞'
2 print(a)
3 print(repr(a))
repr()  json pickle序列化模块 特殊字符串,python字符串的区别


格式化输出 %r
msg = 'alex 是 %r的人' % ('德高望重')
print(msg)

sorted:对所有可迭代的对象进行排序操作。
sorted(iterable,key,reverse=)
iterable:可遍历的对象:
key:接受的函数
reverse翻转
字符串排序,返回排序后的列表
1 str ='2abc3de5f1g'
2 print(sorted(str,reverse=True))  #可以将字符转转换为列表,注意与split的区别
列表的排序
 1 lis = [1,2,'a',6,'p']
 2 print(sorted(lis))  #不支持字符串和和数字列表直接排序'<' not supported between instances of 'str' and 'int'
 3 lis1 = [2,4,6,7,1,9,3]
 4 print(sorted(lis1))   #形成的时一个新列表,原列表不变
 5 l2 = [(1,1000),(2,18),(4,250),(3,500)]
 6 print(sorted(l2))
 7 
 8 def func1(x):
 9     return x[1]
10 print(sorted(l2,key=func1,reverse=True))
字典的排序
1 dic = {3:2,2:5,7:6,1:0}
2 print(sorted(dic))  #默认是以key排序
3 print(sorted(dic,key=lambda x:dic[x])) #自定义函数按后面元素排序
enumerate:枚举,返回一个枚举对象。可以用循环遍历得到对象的元素对应的所以和元素组成的元祖
1 ls =[1,2,3,4,5]
2 print(enumerate(ls))    #<enumerate object at 0x000001942E68C750>
3 print(list(enumerate(ls)))  #[(0, 1), (1, 2), (2, 3), (3, 4), (4, 5)]
4 for i in enumerate(ls,1):   #可以修改索引的初始值
5     print(i)
结果
(1, 1)
(2, 2)
(3, 3)
(4, 4)
(5, 5)

all:可迭代对象中,全都是True才是True 或为空时为True *** 多做条件判断
1 l1 = [1,'',[1,3],(2,4)]
2 print(all(l1))
3 l2 = []
4 l3 = {}
5 l4 =''
6 print(all(l2))
7 print(all(l3))
8 print(all(l4))
any:可迭代对象中,有一个True 就是True ,或为空时False ***  多做条件判断
1 print(any([1,0,'',()]))
2 print(any([]))
zip:函数用于将可迭代的对象作为参数,将对象中对应的元素打包成一个个元组,然后返回由这些元组组成的列表。 *****
如果各个迭代器的元素个数不一致,则返回列表长度与最短的对象相同。
拉链方法 将多个iter 纵向组成一个个元组。
l1 = [1,2,3,5,6,7]
tu1 = ('alex','太白', 'wusir', '女神')
dic = {'name': '日天', 'age':28, 'hobby': 'tea', 'weight':100}
# print(zip(l1,tu1,dic))
for i in zip(l1,tu1):
    print(i)
filter:过滤· 迭代器。 *****
filter(function=,iterable=)
function为可自定值得函数(过滤条件)
iterable为可迭代对象
1 l1 = [i for i in range(10)]
2 def func1(x):
3     return x % 2 == 0
4 print(list(filter(func1,l1)))
map:会根据提供的函数对指定序列做映射,返回映射对象。 循环模式
map(function,iter1,iter2)
 1 l1 = [1,2,3,4]
 2 # print([i**2 for i in l1])
 3 def func(x): return x**2
 4 print(list(map(func,l1)))
 5 
 6 l2 =[1,2,3,4,5]
 7 l3 = ['a','b','c','d']
 8 l4 = ['a','b','c','d']
 9 def add(x,y,z):
10     return x*y+z
11 print(list(map(add,l3,l2,l4)))
匿名函数  lambda表达式,
普通函数 有且只有返回值的函数才可以用匿名函数进行简化,一行函数。
func2 = lambda x: x*2
相当于
def func2(x):
return x**2

匿名函数可以赋值给变量
1 func2 = lambda x : x**2
2 print(func2(6))
3 
4 func2 = lambda x,y: x+y
5 print(func2(1,2))
匿名函数 不单独使用,多与内置函数结合。
1 l2 = [(1,1000),(2,18),(4,250),(3,500)]
2 print(sorted(l2,key=lambda x:x[1]))
匿名函数可以用于三元运算
1 func = lambda x,y:x if x > y else y
2 print(func(89,98))
实例:
 1 dic={'k1':10,'k2':100,'k3':30}
 2 #1,利用内置函数匿名函数将dic按照值进行排序。
 3 print(sorted(dic,key=lambda x:dic[x]))
 4 print(sorted(dic.items(),key=lambda x:x[1]))
 5 [1,5,7,4,8]
 6 #利用内置函数匿名函数 计算列表的每个数的2倍。
 7 print(list(map(lambda x:x*2,[1,5,7,4,8])))
 8 [5,8,11,9,15]
 9 #利用内置函数匿名函数,将值大于10的留下来。
10 print(list(filter(lambda x: x>10,[5,8,11,9,15])))

posted @ 2018-08-22 19:09  麒麟610  阅读(234)  评论(0编辑  收藏  举报