Python列表建议收藏

在python中有六种内建的序列:列表、元祖、字符串、Unicode字符串、buffer对象和xrange对象。通用序列操作:1.索引(indexing)2.分片(slicing)3.

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

Python列表建议收藏此处内容已经被作者隐藏,请输入验证码查看内容
验证码:
请关注本站微信公众号,回复“”,获取验证码。在微信里搜索“”或者“”或者微信扫描右侧二维码都可以关注本站微信公众号。

python中有六种内建的序列:列表、元祖、字符串、Unicode字符串、buffer对象和 xrange对象。

通用序列操作:

  1. 索引(indexing)

  2. 分片(slicing)

  3. 加(adding)

  4. 乘(multiplying)

  5. 检查某个元素是否属于这序列的index(in)

  6. 计算序列的长度(len)

  7. 找出最大元素和最小元素(max/min)

本篇将介绍其中的列表,以下从列表定义增删改查、列表生成式三个方面进行总结

1. 列表定义

  列表为Python内置数据类型,用[]表示,可以修改

2. 列表的增、删、改,查

  (1) 增

  append()

  extend() #必须在列表尾部拼接另一个链表

  insert() #指定索引位置插入字符

  (2) 删

  pop() #删除末尾的元素

  remove() #指定值进行删除

  del()  #用索引和切片进行删除

  clear() #清楚列表中的所有元素,保留列表这个对象

  (3) 查

  索引

  切片

  count()

  max()/min()

  (4) 排序

  sort()

  reserve()

  sorted() #对一个列表集合按照列表中某个位置的元素进行排序

li = [[1,2,3,4],[4,3,2,1],[2,4,1,3]]
destli = sorted(li, key = lambda element:element[3])
print (li)
print (destli)

>>> [[1, 2, 3, 4], [4, 3, 2, 1], [2, 4, 1, 3]]
>>> [[4, 3, 2, 1], [2, 4, 1, 3], [1, 2, 3, 4]]

  3. 列表生成式

  >>>[i for i in range(10) if i %2 == 0]

  [0, 2, 4, 6, 8]

  内建函数enumerate() 作用:在列表中为获得序号提供了一个更方便的方法

  >>>seq = ['a', 'b', 'c']

  >>>for i, element in enumerate(seq): seq[i] = "%d%s"%(i, element)

  4. enumerate

  >>> for a,b in enumerate([1,2,3,4]):
    >>>  print (a, b)

  5. zip

  >>> for item in zip([1,2,3], [4,5,6]):

  >>> print (item)

  (1, 4) (2, 5)(3,6)

  >>> for item in zip(*zip([1,2,3], [4,5,6])):

  >>> print (item)

  (1,2,3)(4,5,6) 

  例:列表合并

Python列表建议收藏
Python列表建议收藏

#coding = utf-8

'''
    合并两个有序列表
'''
l1 = [1,3,5,7,8]
l2 = [2,4,6,9]

def _recursion_merge_sort2(l1, l2, tmp):
    if len(l1) == 0 or len(l2) == 0:
        tmp.extend(l1)
        tmp.extend(l2)
        return tmp
    else:
        if l1[0] < l2[0]:
            tmp.append(l1[0])
            del l1[0]
        else:
            tmp.append(l2[0])
            del l2[0]
        return _recursion_merge_sort2(l1, l2, tmp)
 
def recursion_merge_sort2(l1, l2):
    return _recursion_merge_sort2(l1, l2, [])

print (recursion_merge_sort2(l1,l2) )

View Code

sort 与 sorted 区别:

sort 是应用在 list 上的方法,sorted 可以对所有可迭代的对象进行排序操作。

list 的 sort 方法返回的是对已经存在的列表进行操作,而内建函数 sorted 方法返回的是一个新的 list,而不是在原来的基础上进行的操作。

extend和append的区别:

l1 = [1,3,5,7,8] l2 = [2,4,6,9]

l3 = []
#l3.append(l1)
#l3.append(l2)
#print (l3)
l3.extend(l1)
l3.extend(l2)
print (l3)

>>> [[1, 3, 5, 7, 8], [2, 4, 6, 9]]

>>> [1, 3, 5, 7, 8, 2, 4, 6, 9]

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/120230.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号