python中列表的常见操作

判断列表是否为空

if not a:
  print "List is empty"

这里是因为空列表会返回一个False

获取列表的索引和值

ints = [8, 23, 45, 12, 78]
for idx, val in enumerate(ints):
    print idx, val
0 8
1 23
2 45
3 12
4 78

合并列表中的子列表

1 method
l=[[1,2,3],[4,5,6], [7], [8,9]]
print([item for sublist in l for item in sublist])
[1, 2, 3, 4, 5, 6, 7, 8, 9]
2 method
l=[[1,2,3],[4,5,6], [7], [8,9]]

print(sum(l, []))
[1, 2, 3, 4, 5, 6, 7, 8, 9]
3 method
from functools import reduce
l=[[1,2,3],[4,5,6], [7], [8,9]]

print(reduce(lambda x,y: x+y,l))
[1, 2, 3, 4, 5, 6, 7, 8, 9]

第一种方法是速度最快的方法

列表中字典的值排序

list_to_be_sorted = [{'name':'Homer', 'age':39}, {'name':'Bart', 'age':10}]
from operator import itemgetter
newlist = sorted(list_to_be_sorted, key=itemgetter('name'))
print(newlist)

把列表分割成同样大小的块

tuple(l[i:i+n] for i in xrange(0, len(l), n))

def chunks(l, n):
    """ Yield successive n-sized chunks from l.
    """
    for i in xrange(0, len(l), n):
        yield l[i:i+n]

合并两个列表

mergedlist = listone + listtwo

列表中随机取一个元素

foo = ['a', 'b', 'c', 'd', 'e']
print(random.choice(foo))

按照步长遍历列表

a[start:end:step] # 按照step步长直到end-1结束,并不是从start一个个遍历到end

Python中的appen和extend

x = [1, 2, 3]
x.append([4, 5])
print (x)
输出:[1, 2, 3, [4, 5]]

x = [1, 2, 3]
x.extend([4, 5])
print (x)
输出:[1, 2, 3, 4, 5]
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,183评论 19 139
  • 〇、前言 本文共108张图,流量党请慎重! 历时1个半月,我把自己学习Python基础知识的框架详细梳理了一遍。 ...
    Raxxie阅读 19,440评论 17 410
  • 吃过晚饭后,我转去超市采购了几件急需物品,顺便看看在超市收银工作的小伙伴。想起每每接到她的电话邀请,都推脱到下次见...
    曌月靓颖阅读 3,207评论 0 1
  • 有句话说,什么年龄做什么事. 记得在微信作家群里我看到篇文章。说如果按照那个逻辑的话,职场妈妈就完全没了自己的...
    燚月仁心阅读 2,415评论 0 0
  • 希子念念阅读 1,535评论 0 1

友情链接更多精彩内容