本文共 811 字,大约阅读时间需要 2 分钟。
首先Python中的map函数是很简单的。意为将第二个参数(一般是数组)中的每一个项,处理为第一个参数的类型。比如如下的代码,将a这个list的每一项都从int类型转化为str类型。
#-*-coding:utf-8-*- a=[1,2,3]; print map(str,a);
运行结果如下:
[‘1’,’2’,’3’] 而如下的数组,则对a这个二维数组中的每一个项的一维数组进行求和操作,最后得出来自然是一个一维数组,因为每一个项的一维数组,转化为一个int。#-*-coding:utf-8-*- a=[[1,3,4],[2,3,2]]; print map(sum,a);
运行结果如下:
[8,7]比如下述的一段代码:
#-*-coding:utf-8-*- x=[1,2,3]; y=[4,5,6]; z=[7,8,9]; print zip(x,y,z);
输出结果:
[(1, 4, 7), (2, 5, 8), (3, 6, 9)]意思是取各个list的第x项,作为返回的二维数组的第x项中的一维数组中的元素。
其实zip还是反过来会这个二维数组操作,但要注意写成zip(*),表示这是一个zip的逆操作。比如下述的一段代码:
# -*-coding:utf-8-*- array=[[1,4,7],[2,5,8],[3,6,9]]; x,y,z=zip(*array); print x,y,z;
运行结果:
(1, 2, 3) (4, 5, 6) (7, 8, 9)因此对于一个数组的转置,代码如下:
# -*-coding:utf-8-*- array = [[1, 4], [2, 5], [3, 6]]; print map(list, zip(*array));
运行结果:
[[1, 2, 3], [4, 5, 6]]转载地址:http://dggli.baihongyu.com/