Мы всегда можем индексировать по строкам и столбцам внутри строк с использованием нормальных операций индексации:
Cписковые включения являются мощным инструментом для обработки таких структур, потому что они автоматически просматривают строки и столбцы. Скажем, хотя такая структура хранит матрицы по строкам, для сбора значений второго столбца мы можем просто проходить по строкам и извлекать желаемый столбец или проходить по позициям в строках с индексаций в ходе дела:
M = [[1, 2, 3],
[4, 5, 6],
[7, 8, 9]]
М[1] # [4, 5, 6]
М[1][2] # 6 (Строка 2, элемент 3)
Cписковые включения являются мощным инструментом для обработки таких структур, потому что они автоматически просматривают строки и столбцы. Скажем, хотя такая структура хранит матрицы по строкам, для сбора значений второго столбца мы можем просто проходить по строкам и извлекать желаемый столбец или проходить по позициям в строках с индексаций в ходе дела:
[row[1] for row in M] # [2, 5, 8]
С применением функции
range()
генерируется список смещений и производится индексация с одинаковыми номерами строк и столбцов, выбирающая М[0][0], затем М[1][1]
и т.д. Во второй строке индекс столбца уравновешивается для извлечения М[0][2]
, М[1][1]
и т.д. (мы предполагаем, что матрица имеет равное количество строк и столбцов):M = [[1, 2, 3],
[4, 5, 6],
[7, 8, 9]]
# Диагональ
[M[i][i] for i in range(len(M))] # [1, 5, 9]
# Обратная диагональ
[M[i][len(M)-1-i] for i in range(len(M))] # [3, 5, 7]
В данном случае однократное списковое включение «сплющивает» матрицу до вектора, т.е. списка чисел. Чтобы понять такой код, его можно преобразовать к виду простых операторов:
Чтобы сохранить матрицу, достаточно использовать двойное списковое включение:
res = []
for row in М: # Эквиваленты в виде операторов
for col in row: # Отступ для частей, находящихся дальше справа
res.append(col + 10)
Чтобы сохранить матрицу, достаточно использовать двойное списковое включение:
[[col + 10 for col in row] for row in M]
Что выведет код?
Anonymous Quiz
60%
[2, 4, 6, 12, 15, 18, 28, 32, 36]
25%
[[2, 4, 6], [12, 15, 18], [28, 32, 36]]
10%
[2, 6, 12, 8, 15, 24, 14, 24, 36]
5%
Error
Мы можем использовать списковые включения для комбинирования значений множества матриц. В задаче выше строится плоский список, который содержит результат попарного перемножения матриц.
Списковое включение может применяться также как разновидность операции проецирования столбцов. Стандартный API-интерфейс для работы с базами данных SQL в Python возвращает результаты запросов в форме последовательности последовательностей вроде следующей ниже; список представляет таблицу, кортежи — строки, а элементы в кортежах — значения столбцов:
С использованием цикла
«столбца» вручную, но списковые включения способны выполнить такую работу за один шаг, к тому же быстрее:
listoftuples = [('bob', 35, 'mgr'), ('sue', 40, 'dev'), ('jack', 51, 'cio')]
С использованием цикла
for
можно было бы извлечь все значения из выбранного«столбца» вручную, но списковые включения способны выполнить такую работу за один шаг, к тому же быстрее:
[age for (name, age, job) in listoftuples] # 35, 40, 52
Как по умолчанию сортирует pandas.sort_values()?
Anonymous Quiz
14%
По убыванию
65%
По возрастанию
9%
Pandas решает сам на основании характера данных
12%
Без явного указания типа сортировки не запустится
DataFrame.sort_values(by, *, axis=0, ascending=True, inplace=False, kind='quicksort', na_position='last', ignore_index=False, key=None)
Булевый параметр
ascending
отвечает за тип сортировки и по умолчанию равен True, т.е. датафрейм сортируется по умолчанию от меньшего к большему.Чем отличается генераторная функция с yield от классической?
Anonymous Quiz
30%
Возвращает управление вызывающему коду на каждой итерации
14%
При ее возобновлении восстанавливается предыдущее состояние i и N
56%
Все вышеперечисленное