Списки являются одним из наиболее часто используемых типов данных. В этой статье собраны 10 наиболее часто задаваемых вопросов и ответов об операциях со списками в StackOverflow. Если вы столкнулись с этими проблемами в процессе разработки, вы можете сначала подумать о том, как их решить. .
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
Параметр должен быть итерируемым объектом, что означает добавление всех элементов объекта в конец списка один за другим.
x = [1, 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]
Элементы от начала до конца-1 позиция. step представляет размер шага, значение по умолчанию равно 1, что означает непрерывное получение, если step равно 2, это означает, что захватываются все остальные элементы.
a = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
>>> a[3:8] # 第3到第8位置之间的元素
[4, 5, 6, 7, 8]
>>> a[3:8:2] # 第3到第8位置之间的元素,每隔一个元素获取
[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)
Третий метод:
import copy
# 浅拷贝
new_list = copy.copy(old_list)
# 深拷贝
new_list = copy.deepcopy(old_list)
6. Как получить последний элемент в списке
Элементы в индексном списке поддерживают не только положительные, но и отрицательные числа. Положительное число означает индексацию с левой стороны списка, а отрицательное число означает индексирование с правой стороны списка. Есть два способа получить последний элемент.
>>> a = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
>>> a[len(a)-1]
10
>>> a[-1]
10
7. Как отсортировать список
Существует два способа сортировки списка, один из которых состоит в том, что список поставляется сsort
, одна встроенная функцияsorted
. Сложные типы данных можно указать, указавkey
Аргументы отсортированы. Список словарей, отсортированный по возрасту в элементах словаря:
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
Метод, используемый для переупорядочивания исходного списка, указываем ключевой параметр, ключ — анонимная функция, элемент — элемент словаря в списке, сортируем по возрасту в словаре, по умолчанию в порядке возрастания, указываем 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 возвращает удаленный элемент
>>> a = [4, 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. Как объединить два списка
listone = [1, 2, 3]
listtwo = [4, 5, 6]
mergedlist = listone + listtwo
print(mergelist)
>>>
[1, 2, 3, 4, 5, 6]
список реализует+
оператор перегружает так, что+
Не только поддерживает добавление значений, но также поддерживает добавление двух списков, если вы реализуете объект__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
Публикуется одновременно по адресу:foo fish.net/Python-список…