1
caniuse 2017-07-14 19:05:43 +08:00
python 不造,js 里 map 一般用来根据一个数组生成一个另外一个数组,reduce 一般用来对数组里的元素做相邻的判断(比如判断连续的两条记录是否重复), 然后生成新的数组。
|
2
halfcoder 2017-07-14 19:14:30 +08:00
python 的 layout syntax 使其不支持多行 lambda,严重限制了 map/reduce 的使用
|
3
mooncakejs 2017-07-14 19:20:41 +08:00
map 太常用了,数组转换。reduce 求和平均数之类很方便。
|
4
TJT 2017-07-14 22:14:29 +08:00
很常用啊,比如遍历一个字典数组。
``` l = [{'name': 'name', 'age': 10}] for name, age in map(lambda x: (x['name'], x['age']), l): print(name, age) ``` 不过也可以用 List generator 替代,但 map 更高效。 |
5
autoxbc 2017-07-14 22:30:43 +08:00
js 里 reduce 有四个参数,叠加值,当前值,索引值,数组自身,这种便利性远超 for。可能一千行代码也没有 for,但是很难没有 forEach map filter sort reduce。
|
6
v2dead 2017-07-14 22:53:05 +08:00 via Android 1
话说回来,我之前比较喜欢用 reduce,因为很方便,20 行的代码 3 行写完,但里面四五个 lambda 上午写的,下午就看不懂了。
|
7
iConnect OP @v2dead 确实是会有这个情况,嵌套复杂的函数,写的时候比较费脑筋,过了半年回来自己再看都陌生了。所以,有的时候主管说不太影响效率的情况下,尽量写普通的代码,因为一个人写的代码总不能一直都一个人维护。
|
8
crazycabbage 2017-07-14 23:17:05 +08:00 via Android
pool.map ,简单的并行化
|
10
ch3rub1m 2017-07-14 23:33:21 +08:00 via iPhone
太常用了,已经到没有写不下代码的程度了。楼主你可以考虑下其实大部分的 for 循环都可以用 m/r 来替代
|
11
XIVN1987 2017-07-14 23:47:16 +08:00
python 有列表推导、字典推导式,,所以 map 用的比较少
|
12
congeec 2017-07-15 02:33:55 +08:00 1
楼上的你们都用 Python ?这帖子明明是发在 Python 节点啊
Pythonic 的做法就是用 listcomp/dictcomp... 代替 map,我猜这才是楼主提问的原因 只有 9 楼、11 楼说到点上了 补充一点,[hex(x) for x in range(1000)]要比 list(map(hex, range(1000)) 慢 |
13
winglight2016 2017-07-15 12:59:28 +08:00
nosql 数据库不支持关联表的时候,必须用这个才能统计关联数据
|
14
ivechan 2017-07-16 13:33:55 +08:00
#12 说的没错,Python 里更多的用的是 listcomp/dictcomp。
map reduce 是个丑陋的东西。除了看别人代码,我不会取管他。 |
15
romanticbao 2017-07-16 13:40:54 +08:00
当你觉得需要的时候
|