Python学习,这些高阶函数和高级特性值得一学!
Python语言这么火,不论是对于刚开始学习的编程小白或者有接触过其他语言(c/c++/java等等)的同学来说,写代码的时候难免会受本身惯性思维或者其他语言的影响!解决问题的思路有的时候会比较单一,其实Python有很多灵活的解法,比如python的几个高阶函数或者特性!
推导式
- 列表推导式,使用一句表达式构造一个新列表,可包含过滤、转换等操作。
语法:[exp for item in collection if codition]
例子:1-1000内所有偶数组成的列表
2种方法,大家自己对比
#one
res = []
for i in range(1,1001):
if i%2==0:
res.append(i)
print(res)
#two
print([i for i in range(1,1001) if i%2==0])
- 字典推导式,使用一句表达式构造一个新列表,可包含过滤、转换等操作。
语法:{key_exp:value_exp for item in collection if codition}
print({key:value for key,value in enumerate(reversed(range(10)))})
#{0: 9, 1: 8, 2: 7, 3: 6, 4: 5, 5: 4, 6: 3, 7: 2, 8: 1, 9: 0}
- 集合推导式
语法:{exp for item in collection if codition}
set = {i for i in range(10)}#结果{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}
map函数
map(fun, lst),将传入的函数变量func作用到lst变量的每个元素中,并将结果组成新的列表返回
lis = [i**2 for i in range(10)]
print(lis) #[0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
print(list(map(float,lis))) #[0.0, 1.0, 2.0, 3.0, 4.0, 5.0, 6.0, 7.0, 8.0, 9.0]
print(list(map(str,lis))) #[‘0’, ‘1’, ‘4’, ‘9’, ‘16’, ‘25’, ‘36’, ‘49’, ‘64’, ‘81’]
规范字符串
name = [‘gOd’,’zIp’,’NAMe’,’titLE’,’filter’]
print(list(map(str.title,name))) #[‘God’, ‘Zip’, ‘Name’, ‘Title’, ‘Filter’]
filter函数
- 筛选序列
- filter(func, lst),将func作用于lst的每个元素,然后根据返回值是True或False判断是保留还是丢弃该元素。
lis = range(-10,10)
print(list(lis)) #[-10, -9, -8, -7, -6, -5, -4, -3, -2, -1, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
def fun(x):
return x<0
print(list(filter(fun,lis))) #[-10, -9, -8, -7, -6, -5, -4, -3, -2, -1]
zip函数
zip([iterable, …])
用于将可迭代的对象作为参数,将对象中对应的元素打包成一个个元组,然后返回由这些元组组成的列表。
如果各个迭代器的元素个数不一致,则返回列表长度与最短的对象相同,利用 * 号操作符,可以将元组解压为列表。
lis_a = [‘a’,’b’,’c’]
lis_b = [‘aa’,’bb’,’cc’]
lis_c = [‘a’,’b’,’c’,’d’]
lis_ab = list(zip(lis_a,lis_b))
lis_bc = list(zip(lis_b,lis_c))
print(lis_ab) #[(‘a’, ‘aa’), (‘b’, ‘bb’), (‘c’, ‘cc’)]
print(lis_bc) #[(‘aa’, ‘a’), (‘bb’, ‘b’), (‘cc’, ‘c’)]
print(list(zip(*lis_bc))) #[(‘aa’, ‘bb’, ‘cc’), (‘a’, ‘b’, ‘c’)]
几个zip技巧
列表元素依次连接
lis = [i for i in range(10)]
print(list(zip(lis[1:],lis[:-1])))
zip生成字典
print(dict(zip(‘abcd’,’1234’)))
对应列表元素相加
lis1 = [i for i in range(5)]
lis2 = [i*2 for i in range(6)]
lis3 = [i**2 for i in range(5)]
lis = []
for x,y,z in zip(lis1,lis2,lis3):
lis.append(x+y+z)
print(lis)
列表元素依次连接
[(1, 0), (2, 1), (3, 2), (4, 3), (5, 4), (6, 5), (7, 6), (8, 7), (9, 8)]
zip生成字典
{'a': '1', 'b': '2', 'c': '3', 'd': '4'}
对应列表元素相加
[0, 4, 10, 18, 28]
zip是一个非常重要的函数,非常方便.熟悉掌握zip帮我们大幅的减少函数的代码和复杂度,并且提高效率!
最后
其实Python的技巧非常非常多,大家平时的写代码或者读代码的时候要注意收集,特别是有一些精妙的招数,一时半会无法领悟,可以记下来,慢慢思考,总有一天会对你的功力增长大有裨益.
还是那句话,代码一定要多练习才能掌握!大家加油!

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
-
上一篇
guava快速入门(二)
Guava工程包含了若干被Google的 Java项目广泛依赖 的核心库,例如:集合 [collections] 、缓存 [caching] 、原生类型支持 [primitives support] 、并发库 [concurrency libraries] 、通用注解 [common annotations] 、字符串处理 [string processing] 、I/O 等等。 guava类似Apache Commons工具集 Collection 不可变集合 不可变对象有很多优点,包括: 当对象被不可信的库调用时,不可变形式是安全的; 不可变对象被多个线程调用时,不存在竞态条件问题 不可变集合不需要考虑变化,因此可以节省时间和空间。所有不可变的集合都比它们的可变形式有更好的内存利用率(分析和测试细节); 不可变对象因为有固定不变,可以作为常量来安全使用。 JDK也提供了Collections.unmodifiableXXX方法把集合包装为不可变形式,但: 笨重而且累赘:不能舒适地用在所有想做防御性拷贝的场景; 不安全:要保证没人通过原集合的引用进行修改,返回的集合才是事实上不可变的...
-
下一篇
Java集合框架源码解析之LinkedHashMap
HashMap 是用于映射(键值对)处理的数据类型,不保证元素的顺序按照插入顺序来排列,为了解决这一问题,Java 在 JDK1.4 以后提供了 LinkedHashMap 来实现有序的 HashMap LinkedHashMap 是 HashMap 的子类,它保留了元素的插入顺序,在内部维护着一个按照元素插入顺序或者元素访问顺序来排列的链表,默认是按照元素的插入顺序来排列,就像使用 ArrayList 一样;如果是按照元素的访问顺序来排列,则访问元素后该元素将移至链表的尾部,可以以此来实现 LRUcache 缓存算法 一、结点类 前面说了,LinkedHashMap 是 HashMap 的子类,即 LinkedHashMap 的主要数据结构实现还是依靠 HashMap 来实现,LinkedHashMap 只是对 HashMap 做的一层外部包装,这个从 LinkedHashMap 内声明的结点类就可以看出来 Entry 类在 Node 类的基础上扩展了两个新的成员变量,这两个成员变量就是 LinkedHashMap 来实现有序访问的关键,不管结点对象在 HashMap 内部为了解决哈...
相关文章
文章评论
共有0条评论来说两句吧...