每日一发Python---Python中大佬都知道的内置函数,你不知道就out了
2017-08-18 09:57
330 查看
转自于:https://www.baidu.com/home/news/data/newspage?source=pc&nid=3201722358414659689&n_type=&p_from=4
1.sorted()
1)对于一个列表排序
sorted([100, 98, 102, 1, 40])
2)通过key参数/函数
比如一个长列表里面嵌套了很多字典元素,我们要按照每个元素的长度大小排序
L = [{1:5,3:4},{1:3,6:3},{1:1,2:4,5:6},{1:9}]
3)对由tuple组成的List排序
比如下面是学生里面的年龄的一个list
students = [('wang', 'A', 15), ('li', 'B', 12), ('zhang', 'B', 10)]
2. map可以根据提供的函数对指定序列做映射,它接受一个函数f和一个list,并通过把函数f以此作用在list上的每个元素,然后返回一个新的list,map函数的入参也可以是多个.注意这个函数一定要有返回值(值值值重要的说三遍)。
不然就会返回新的list 类似[None, None, None, None, None, None, None, None, None]
def fun(x):
return x*x;
list=[1,2,3]
list=map(fun,list)
print list
3.enumerate()
Python中,迭代永远是取出元素本身,而非元素的索引,有的时候我们需要知道元素的索引比如在一个很长的列表里面是一些网站名,我们希望在打印的时候,也能列出索引。若没有这个函数,我们需要在加一个变量,在循环打印的时候让这个计数变量递增,现在有了enumerate,就不用这么麻烦了,直接搞定.
4.zip()
zip函数接受任意多个(包括0个和1个)序列作为参数,返回一个tuple列表
x = [1, 2, 3]
这个函数特别是在构建字典序列的时候非常方便 (这招非常巧妙,大家可以仔细揣摩)
5.filter()
filter函数接受一个函数f和一个list,这个函数f的作用是对每个元素进行判断,返回True或者False,这样可以过滤掉一些不符合条件的元素,然后返回符合条件的list.
def is_even(x):
特别是在处理文件的时候,需要把一些空格,回车和空字符去掉
6.reduce()
reduce函数的用法和map很类似,也是一个函数f和一个list,但是函数的入口参数一定要是两个,reduce也是对每个元素进行反复调用,最后返回最终的值,而map是返回一个list
注意在python3里面reduce已经从全局函数里面移除了,需要用的话要from functools import
1.sorted()
1)对于一个列表排序
sorted([100, 98, 102, 1, 40])
2)通过key参数/函数
比如一个长列表里面嵌套了很多字典元素,我们要按照每个元素的长度大小排序
L = [{1:5,3:4},{1:3,6:3},{1:1,2:4,5:6},{1:9}]
3)对由tuple组成的List排序
比如下面是学生里面的年龄的一个list
students = [('wang', 'A', 15), ('li', 'B', 12), ('zhang', 'B', 10)]
>>> list=[1,2,8,7] >>> sorted(list) [1, 2, 7, 8] >>> list= [{1:5,3:4},{1:3,6:3},{1:1,2:4,5:6},{1:9}] >>> sorted(list) [{1: 9}, {1: 3, 6: 3}, {1: 5, 3: 4}, {1: 1, 2: 4, 5: 6}] >>> list=[('wang', 'A', 15), ('li', 'B', 12), ('zhang', 'B', 10)] >>> sorted(list) [('li', 'B', 12), ('wang', 'A', 15), ('zhang', 'B', 10)]
2. map可以根据提供的函数对指定序列做映射,它接受一个函数f和一个list,并通过把函数f以此作用在list上的每个元素,然后返回一个新的list,map函数的入参也可以是多个.注意这个函数一定要有返回值(值值值重要的说三遍)。
不然就会返回新的list 类似[None, None, None, None, None, None, None, None, None]
def fun(x):
return x*x;
list=[1,2,3]
list=map(fun,list)
print list
[1, 4, 9]适合的场景是对列表里面的一些元素需要重复的操作,用map就可以轻松搞定.
3.enumerate()
Python中,迭代永远是取出元素本身,而非元素的索引,有的时候我们需要知道元素的索引比如在一个很长的列表里面是一些网站名,我们希望在打印的时候,也能列出索引。若没有这个函数,我们需要在加一个变量,在循环打印的时候让这个计数变量递增,现在有了enumerate,就不用这么麻烦了,直接搞定.
list=[1,2,3,4] for index,e in enumerate(list): print (index,e) (0, 1) (1, 2) (2, 3) (3, 4)
4.zip()
zip函数接受任意多个(包括0个和1个)序列作为参数,返回一个tuple列表
x = [1, 2, 3]
这个函数特别是在构建字典序列的时候非常方便 (这招非常巧妙,大家可以仔细揣摩)
list=[1,2,3,4] list2=["abc","a","aa","cc"] newlist=zip(list,list2); print newlist new_dic=dict(newlist) print new_dic [(1, 'abc'), (2, 'a'), (3, 'aa'), (4, 'cc')] {1: 'abc', 2: 'a', 3: 'aa', 4: 'cc'}
5.filter()
filter函数接受一个函数f和一个list,这个函数f的作用是对每个元素进行判断,返回True或者False,这样可以过滤掉一些不符合条件的元素,然后返回符合条件的list.
def is_even(x):
特别是在处理文件的时候,需要把一些空格,回车和空字符去掉
6.reduce()
reduce函数的用法和map很类似,也是一个函数f和一个list,但是函数的入口参数一定要是两个,reduce也是对每个元素进行反复调用,最后返回最终的值,而map是返回一个list
注意在python3里面reduce已经从全局函数里面移除了,需要用的话要from functools import
相关文章推荐
- 每日一发Python---Python中的__name__和类
- 每日一发Python---Python yield 使用浅析
- 每日一发Python---Python中shelve模块用法
- Python中你应该知道的一些内置函数
- 每日一发Python---Python基础及安装
- Python3中的内置函数,实例讲解-每日持续更新
- 每日一发Python---Python中双冒号的作用[::]
- 每日一发Python---python中的enumerate函数
- 每日一发Python---python list转字符串会显示u'的问题
- Python内置函数(23)——format
- python内置函数
- [每日一记] Python报错 综述
- [python每日一练]--0004:统计文档内的单词个数
- 你可能不知道的30个Python语言的特点技巧
- python Built-in Functions(python内置函数)
- python内置函数总结
- 三极管(如NPN)集电极正偏 发射极反偏会怎么样呢? 电流会倒流吗? 其他三种都知道,就是不知道这种情况
- Python: 你不知道的 super
- Python每日一练0010
- python(45)内置函数:os.system() 和 os.popen()