列表是Python中应用数最多的一种数据信息結果,怎样高效率操作列表是提升 代码运行高效率的重要,这篇文章列出了10个常见的列表操作,期待对给你协助。

1、迭代更新列表时怎样浏览列表字符数据库索引

一般版:

items = [8, 23, 45]
for index in range(len(items)):
    print(index, "-->", items[index])
​
>>>
0 --> 8
1 --> 23
2 --> 45

雅致版:

for index, item in enumerate(items):
    print(index, "-->", item)
​
>>>
0 --> 8
1 --> 23
2 --> 45

enumerate 还能够特定原素的第一个原素从几刚开始,默认设置是0,还可以特定从1刚开始:

for index, item in enumerate(items, start=1):
    print(index, "-->", item)
​
>>>
1 --> 8
2 --> 23
3 --> 45

2、append 与 extend 方式有什么不同

append表明把某一数据信息作为新元素增加到列表的最终面,它的主要参数能够是随意目标

x = [1, 2, 3]
y = [4, 5]
x.append(y)
print(x)
​
>>>
[1, 2, 3, [4, 5]]

extend 的主要参数务必是一个可迭代更新目标,表明把该目标里边的全部原素逐一地增加到列表的后边

#Python学习培训 2, 3]
y = [4, 5]
x.extend(y)
print(x)
​
>>>
[1, 2, 3, 4, 5]
​
# 等额的于:
for i in y:
    x.append(i)

3、查验列表是不是为空

一般版:

 if len(items) == 0:
     print("空列表")

或是

if items == []:
    print("空列表")

雅致版:

if not items:
    print("空列表")

4、怎样看待切成片

切成片用以获得列表中特定范的非空子集,英语的语法比较简单

items[start:end:step]

从 start 到 end-1 部位中间的原素。step 表明步幅,默认设置为1,表明持续获得,假如 step 为 2 就表明每过一个原素获得。

a = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
​
>>> a[3:8] # 第三到第八部位中间的原素
[4, 5, 6, 7, 8]
​
>>> a[3:8:2] # 第三到第八部位中间的原素,每过一个原素获得
[4, 6, 8]
​
>>> a[:5]   # 省去start表明从第0个原素刚开始
[1, 2, 3, 4, 5]
​
>>> a[3:]  # 省去end表明到最后一个原素
[4, 5, 6, 7, 8, 9, 10]
​
>>> a[::]  # 都省去等同于复制一个列表,这类复制归属于浅拷贝
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

5、怎样复制一个列表目标

第一种方式:

new_list = old_list[:]

第二种方式:

new_list = list(old_list)

第三种方式:

#Python学习培训 2, 3, 4, 5, 6, 7, 8, 9, 10]
>>> a[len(a)-1]

10
>>> a[-1]
10

7、怎样对列表开展排列

列表排列有二种方法,一种是列表内置的方法 sort,一种是内建函数 sorted。繁杂的基本数据类型可根据特定 key主要参数开展排列。由词典组成的列表,依据词典原素中的age字段名开展排列:

items = [{'name': 'Homer', 'age': 39},
         {'name': 'Bart', 'age': 10},
         {"name": 'cater', 'age': 20}]

items.sort(key=lambda item: item.get("age"))

print(items)

>>>
[{'age': 10, 'name': 'Bart'}, {'age': 20, 'name': 'cater'}, {'age': 39, 'name': 'Homer'}]

列表有 sort方式,用以对原列表开展再次排列,特定 key 主要参数,key 是匿名函数,item 是列表中的词典原素,大家依据词典中的age开展排列,默认设置是按升序排序,特定

reverse=True 
按降序排序

 items.sort(key=lambda item: item.get("age"), reverse=True)
 >>>
 [{'name': 'Homer', 'age': 39}, {'name': 'cater', 'age': 20}, {'name': 'Bart', 'age': 10}]

如果不期待更改原列表,只是形成一个新的井然有序列表目标,那麼能够内嵌涵数 sorted ,该涵数回到新列表

items = [{'name': 'Homer', 'age': 39},
         {'name': 'Bart', 'age': 10},
         {"name": 'cater', 'age': 20}]

new_items = sorted(items, key=lambda item: item.get("age"))

print(items)
>>>
[{'name': 'Homer', 'age': 39}, {'name': 'Bart', 'age': 10}, {'name': 'cater', 'age': 20}]

print(new_items)
>>>
[{'name': 'Bart', 'age': 10}, {'name': 'cater', 'age': 20}, {'name': 'Homer', 'age': 39}]

8、怎样清除列表中的原素

删掉列表中的原素有三种方法

remove 清除某一原素,并且只有清除第一次出現的原素

>>> a = [0, 2, 2, 3]
>>> a.remove(2)
>>> a
[0, 2, 3]


# 假如要清除的原素没有列表中,则抛出去 ValueError 出现异常
>>> a.remove(7)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ValueError: list.remove(x): x not in list·

del 依据特定的部位清除某原素

>>> a = [3, 2, 2, 1]
# 清除第一个原素
>>> del a[1]
[3, 2, 1]

# 当超过列表的下列数据库索引时,抛出去IndexError的出现异常
>>> del a[7]
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
IndexError: list assignment index out of range

pop 与del 相近,可是 pop 方式能够回到清除的原素

#Python学习培训 3, 5]
>>> a.pop(1)
3
>>> a
[4, 5]

# 一样,当超过列表的下列数据库索引时,抛出去IndexError的出现异常
>>> a.pop(7)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
IndexError: pop index out of range

9、如何连接2个列表

listone = [1, 2, 3]
listtwo = [4, 5, 6]

mergedlist = listone   listtwo

print(mergelist)
>>>
[1, 2, 3, 4, 5, 6]

列表完成了 的运算符重载,促使 不但适用标值求和,还适用2个列表求和,如果你完成了 目标的 add操作,一切目标都能够完成 操作,比如:

class User(object):
    def __init__(self, age):
        self.age = age
​
    def __repr__(self):
        return 'User(%d)' % self.age
​
    def __add__(self, other):
        age = self.age   other.age
        return User(age)
​
user_a = User(10)
user_b = User(20)
​
c = user_a   user_b
​
print(c)
​
>>>
User(30)

10、怎样任意获得列表中的某一原素

import random
items = [8, 23, 45, 12, 78]
​
>>> random.choice(items)
78
>>> random.choice(items)
45
>>> random.choice(items)
12
文章来源于网络,如有侵权请联系站长QQ61910465删除
本文版权归QU快排Www.seoGurubLog.com 所有,如有转发请注明来出,竞价开户托管,seo优化请联系QQ▲61910465