juan503949201的个人博客分享 http://blog.sciencenet.cn/u/juan503949201

博文

python的map和zip操作

已有 3060 次阅读 2014-4-11 01:14 |个人分类:python|系统分类:科研笔记

如果要将一个string list转换成int list (list里每个string都转成int),比如

[python] view plaincopy
  1. ['0','1','2'] -> [0,1,2]  

可以使用:
[python] view plaincopy
  1. [int(x) for x in list]  

或者使用map操作: map(func, list) 对list里的每个元素apply func.
[python] view plaincopy
  1. map(int, list)  

假设有一个2维数组(用list实现):
[python] view plaincopy
  1. list = [[0,1,2],[3,1,4]]  

如果要得到每行之和,可以用以下两种方式:
[python] view plaincopy
  1. >>> list = [[0,1,2],[3,1,4]]  

  2. >>> [sum(x) for x in list]  

  3. [3, 8]  

  4. >>> map(sum,list)  

  5. [3, 8]  

如果要得到每列之和,需要用zip(*list)先unzip list,得到一个元组list,其中第i个元组包含了每行的第i个元素:
[python] view plaincopy
  1. >>> list = [[0,1,2],[3,1,4]]  

  2. >>> zip(*list)  

  3. [(0, 3), (1, 1), (2, 4)]  

  4. >>> [sum(x) for x in zip(*list)]  

  5. [3, 2, 6]  

  6. >>> map(sum,zip(*list))  

  7. [3, 2, 6]

下面的例子是关于zip和unzip(其实是zip和*一起用)如何work的:
[python] view plaincopy
  1. >>> x=[1,2,3]  

  2. >>> y=[4,5,6]  

  3. >>> zipped = zip(x,y)  

  4. >>> zipped  

  5. [(1, 4), (2, 5), (3, 6)]  

  6. >>> x2,y2=zip(*zipped)  

  7. >>> x2  

  8. (1, 2, 3)  

  9. >>> y2  

  10. (4, 5, 6)  

  11. >>> x3,y3=map(list,zip(*zipped))  

  12. >>> x3  

  13. [1, 2, 3]  

  14. >>> y3  

  15. [4, 5, 6]    


第一个参数接收一个函数名,第二个参数接收一个可迭代对象

  1. 复制代码
    ls = [1,2,3]
    rs = map(str, ls)
     
    #打印结果 ['1', '2', '3']
    lt = [1, 2, 3, 4, 5, 6]
    def add(num):
       return num + 1
     
    rs = map(add, lt)
    print rs #[2,3,4,5,6,7]

      

     
    复制代码

                                                                                                                                                 



https://blog.sciencenet.cn/blog-1271266-783796.html

上一篇:Python strip lstrip rstrip使用方法
下一篇:比较常用的几个正则表达式(匹配数字)
收藏 IP: 14.204.27.*| 热度|

0

该博文允许注册用户评论 请点击登录 评论 (0 个评论)

数据加载中...

Archiver|手机版|科学网 ( 京ICP备07017567号-12 )

GMT+8, 2024-4-24 12:49

Powered by ScienceNet.cn

Copyright © 2007- 中国科学报社

返回顶部