7 основных способов для управления столбцами в Pandas
Когда дело доходит до анализа данных, Pandas является наиболее используемой библиотекой Python для обработки и подготовки данных для дальнейшего анализа и машинного обучения.
Реальность такова, что Pandas — действительно гибкая библиотека, и её можно использовать даже для преобразования форматов файлов.
Однако, даже если мы используем некоторые функции Pandas едва ли не каждый день, мы тратим много времени на интернет-сёрфинг (поиск ответов на то, как что-то сделать в Pandas?).
Но давайте будем честными: некоторые функции трудно запомнить потому, что мы можем достичь одной и той же цели разными способами. Так что нечего стыдиться, если мы каждый день гуглим одни и те же вещи.
Тем не менее, экономия времени — это всегда хорошая идея. По этой причине в этой статье мы рассмотрим 7 основных способов для управления столбцами в Pandas. Таким образом, вам больше не нужно будет их гуглить: вам просто нужно сохранить эту статью (возможно, в закладках) и возвращаться к ней всякий раз, когда она вам понадобится.
Вот что вы найдете здесь:
Оглавление:
Как создать новый столбец в Pandas
Как переименовать столбец в Pandas
Как добавить новый столбец во фрейм данных Pandas
Как удалить столбец в Pandas
Как найти уникальные значения в столбце Pandas
Как преобразовать столбец Pandas в список
Как отсортировать фрейм данных Pandas по столбцам
Как создать новый столбец в Pandas
Есть несколько способов создать новый столбец Pandas. Давайте посмотрим их все!
Создайте столбец Pandas как Pandas Series
Правильный метод создания столбца Pandas, который, как считается, «живёт» сам по себе, — это метод Series, который мы рассматриваем ниже:
Я сказал «правильный метод», потому что, как мы уже говорили, столбец Pandas — это то же самое что Pandas Series. Итак, если нам нужен только один столбец, мы должны использовать этот метод, если нам хочется быть «формально правильными».
Создайте столбец Pandas как фрейм данных Pandas
Однако реальность такова, что столбец сам по себе нам понадобится нечасто.
Итак, ещё один способ создать столбец в Pandas — создать новый фрейм данных только с одним столбцом: таким образом, мы могли бы мгновенно обогатить его другими столбцами.
Мы можем сделать это так:
Отличие от предыдущего примера в том, что в этом случае столбец Pandas также имеет имя. В данном случае мы назвали его «А».
ПРИМЕЧАНИЕ: Если мы более внимательно посмотрим на то, что мы здесь сделали, увидим, что мы можем создать фрейм данных Pandas как словарь. Фактически, «A» — это ключ, и он разделён списком значений через двоеточие. Затем и ключи, и значения находятся внутри фигурных скобок.
Создайте столбец Pandas как фрейм данных Pandas, начиная с массива NumPy
Одной из сверхспособностей Pandas является то, что он может «принимать» массивы NumPy в качестве входных значений. Другими словами, мы можем создать фрейм данных, начиная с массива NumPy.
В случае одного столбца мы можем создать одномерный массив и преобразовать его во фрейм данных: в результате получится фрейм данных с одним столбцом.
Мы можем сделать это так:
Как добавить новый столбец во фрейм данных Pandas
Возможность добавить новый столбец во фрейм данных Pandas каким-то образом связана с созданием нового столбца.
Я имею в виду, что сначала нам нужно создать фрейм данных Pandas, затем один столбец Pandas, затем нам нужно добавить столбец в фрейм данных.
В этом случае у нас также есть несколько возможностей сделать это. Давайте посмотрим их все.
Добавление нового столбца во фрейм данных Pandas: стандартный метод
Стандартный метод добавления нового столбца во фрейм данных Pandas — создать фрейм данных, далее создать отдельный столбец, а затем добавить его во фрейм данных.
Мы будем использовать этот метод во всех следующих примерах. Итак, вот как мы можем это сделать:
Давайте пошагово разберем, что мы сделали:
- Мы создали фрейм данных Pandas с помощью метода pd.DataFrame().
- Мы создали новый столбец df['B'], который назвали «B».
- Мы присвоили значения вновь созданному столбцу со списком чисел.
Добавление нового столбца во фрейм данных Pandas: применение функций
Возможности стандартного метода добавления нового столбца в существующий фрейм данных дают нам возможность создать новый столбец и добавить его в существующий фрейм данных одной строкой кода.
Например, предположим, что мы хотим создать два новых столбца как комбинацию существующего столбца. Мы можем сделать это, применяя функции к существующим столбцам следующим образом:
Итак, вот что мы сделали:
- Мы создали столбец Pandas («A») в качестве фрейма данных.
- Мы создали столбец «B», удвоив значения столбца «A».
- Мы создали столбец «C», применив лямбда-функцию к столбцу «A». В частности, в данном случае мы возводим в квадрат значения столбца «А».
Все эти столбцы хранятся вместе в уникальном фрейме данных.
Добавление нового столбца во фрейм данных Pandas: использование Pandas Series или отдельных столбцов Pandas
Конечно, мы можем добавлять столбцы во фрейм данных Pandas, даже если столбцы представляют собой Series или фрейм данных.
Вот как мы можем это сделать:
Итак, в приведённом выше случае мы создали Pandas Series, затем добавили её в существующий фрейм данных, дав ей имя.
В случае столбца Pandas, созданного как фрейм данных, мы имеем следующее:
Как переименовать столбец в Pandas
Переименование столбца Pandas (или нескольких) — ещё одна типичная ежедневная задача, которую нам нужно выполнять, но способ выполнения которой мы часто не можем вспомнить.
Для её реализации существуют различные методы. Давайте посмотрим их все!
Как переименовать столбец Pandas: метод rename()
Мы можем переименовать столбец Pandas с помощью метода rename():
Итак, мы как будто пользуемся словарём. Внутри метода rename() нам нужно передать аргумент columns и указать фактическое имя и новое имя внутри фигурных скобок, разделив их двоеточием. Так же, как мы делаем в словарях.
Конечно, мы можем использовать этот метод для переименования нескольких столбцов одновременно следующим образом:
Как переименовать столбец Pandas: атрибут columns
Чтобы переименовать один столбец в Pandas (или несколько), мы можем использовать атрибут columns следующим образом:
В этом случае атрибут columns даёт нам возможность использовать список строк для переименования столбцов.
Как переименовать столбец Pandas: метод set_axis()
Чтобы переименовать один (или несколько) столбцов в Pandas, мы можем использовать метод set_axis():
Итак, даже в этом случае мы используем список строк для переименования столбцов, но здесь нам также нужно передать параметры axis=1 и inplace=True, поскольку метод set_axis() устанавливает оси с нуля. Это позволяет этому методу переименовывать столбцы.
Как переименовать столбец Pandas: использование лямбда-функций
Когда нам приходится иметь дело со строками, как в случае имён столбцов Pandas, мы можем использовать лямбда-функции для изменения символов текста.
Например, нам может понадобиться переименовать столбцы, просто переведя буквы в нижний регистр. Мы можем сделать это так:
Как удалить столбец в Pandas
Удаление столбца Pandas (или нескольких) — ещё одна задача, которую нам нужно выполнять очень часто. Например потому, что значения какого-то из столбцов могут оказаться несущественны или иметь значения NULL.
Для выполнения этой задачи у нас есть два метода. Давайте посмотрим на них!
Как удалить столбец в Pandas: метод drop()
Типичный способ удалить столбец в Pandas— использовать метод drop().
Здесь единственное, что нужно иметь в виду, так это решить, хотим ли мы удалить некоторые столбцы и создать новый фрейм данных, или мы хотим удалить их и заменить текущий фрейм данных.
Покажу разницу:
Итак, мы удалили столбец «А», используя метод drop(), указывающий имя столбца, который мы хотели удалить, и ось ( axis=1 в Pandas указывает вертикальное направление).
В данном случае мы решили заменить фрейм данных df. Итак, в конце процесса фрейм данных df больше не имеет столбца «А».
Если же мы хотим создать другой фрейм данных, допустим, мы вызываем id df_2, мы должны сделать это так:
Итак, в этом случае мы удалили два столбца и создали новый фрейм данных со столбцами «B» и «C».
Это может быть полезно, если мы думаем, что нам может понадобиться исходный фрейм данных df в будущем для дальнейших анализов.
Как удалить столбец в Pandas: используйте индекс столбца
В Pandas столбцы можно выделить с помощью индексов. Это означает, что мы можем удалить их, используя индексы:
Итак, в этом случае мы создали новый фрейм данных только со столбцами «C» и «D» и удалили столбцы «A» и «B», используя их индексы.
Помня, что в Python мы начинаем индексацию с 0 (первый столбец имеет индекс 0 и является столбцом «A»), мы должны сказать, что этот метод может быть не оптимальным, если у нас есть десятки столбцов по простой причине: мы должны найти тот (или те), которые мы хотим отбросить, путём их подсчёта, что может привести к ошибкам.
Как найти уникальные значения в столбце Pandas
Поиск уникальных значений в столбце Pandas — это ещё одна задача, которую нам, возможно, придется выполнять ежедневно, потому что повторяющиеся значения должны обрабатываться особым образом.
В этом случае у нас есть несколько способов реализовать это. Давайте посмотрим на них.
Как найти уникальные значения в столбце Pandas: используйте метод value_counts() для поиска дубликатов
Если мы хотим увидеть, есть ли в столбце Pandas повторяющиеся значения, и мы также хотим узнать, сколько их, мы можем использовать метод value_counts():
Итак, результат здесь говорит о том, что:
- Имя столбца — «A», а все типы — «int64».
- У нас есть две единицы.
- У нас есть две тройки.
- У нас одна двойка.
Данный метод показывает нам значения и сообщает, сколько из них присутствует в интересующем нас столбце.
Как найти уникальные значения в столбце Pandas: используйте метод drop_duplicates() для удаления дубликатов
Если мы хотим удалить повторяющиеся значения в столбце Pandas (потому что мы знаем, что в нём есть дубликаты), мы можем использовать метод drop_duplicates():
Итак, мы удалили дубликаты из столбца «A», создав новый столбец Pandas с именем unique_values.
Как найти уникальные значения в столбце Pandas: изучение фрейма данных
В этот момент вы можете спросить: « Хорошо, если у меня есть большой фрейм данных с десятками столбцов, как я могу знать, что некоторые столбцы имеют дубликаты?»
Хороший вопрос! Что мы можем сделать, так это сначала изучить весь фрейм данных.
Например, мы можем захотеть увидеть, есть ли дубликаты каких-либо столбцов. Мы можем сделать это так:
Итак, этот код возвращает «True», если есть столбцы с дубликатами, и «False», если их нет.
А как насчет того, чтобы узнать имена столбцов, которые на самом деле имеют дубликаты? Мы можем сделать это так:
Приведённый выше код показывает:
- Столбцы с дубликатами.
- Значения дубликатов.
Теперь мы можем продолжить расследование с помощью метода value_counts() или удалить их с помощью метода drop_duplicates().
Как преобразовать столбец Pandas в список
Преобразование столбца Pandas в список — полезная функция, которая может дать нам возможность «изолировать» все значения из столбца Pandas, чтобы поместить их в список. Затем мы можем делать всё, что нам может понадобиться со списком, которым легко управлять.
У нас есть две возможности сделать это преобразование.
Как преобразовать столбец Pandas в список: метод list()
Метод list() — это встроенная в Python функция, которая преобразует итерируемый объект в список. Мы можем сделать это так:
Итак, мы легко извлекли наши значения и поместили их в список.
Как преобразовать столбец Pandas в список: метод to_list()
Для достижения того же результата мы можем использовать метод to_list() от Pandas. Но будьте осторожны: он доступен в Pandas версии 1.2.0 или выше .
Мы можем сделать это так:
И, конечно же, мы получили тот же результат, что и раньше.
Как отсортировать фрейм данных Pandas по столбцам
Есть много ситуаций, в которых нам нужно отсортировать наши столбцы. Под сортировкой мы подразумеваем упорядочивание, поэтому мы можем упорядочить данные по возрастанию или по убыванию.
Мы можем достичь этой цели следующими методами:
Как отсортировать фрейм данных Pandas по столбцам: метод sort_values()
Чтобы отсортировать фрейм данных Pandas по столбцам, мы можем использовать метод sort_values():
Итак, как мы видим, фрейм данных отсортирован по столбцу «А» в порядке возрастания. На самом деле, если мы проверим:
- Во фрейме исходных данных в столбце «А» цифра 1 стоит на 4-й позиции. В столбце «В» число 28 стоит на четвертой позиции.
- В отсортированном фрейме данных в столбце «А» число 1 стоит на первой позиции. В столбце «В» число 28 стоит на первой позиции.
Итак, мы сортируем фрейм данных, но не теряем связи между значениями столбцов.
Очень полезной особенностью этого метода является то, что он может сортировать столбец, помещая NaNs как первые значения. Мы можем сделать это так:
Как отсортировать фрейм данных Pandas по столбцам: метод sort_index()
Мы также можем отсортировать фрейм данных по значению индекса следующим образом:
И, как мы видим, индексы упорядочены (по возрастанию).
Заключение
В этой статье мы рассмотрели 7 основных операций со столбцами Pandas, которые мы выполняем едва ли не каждый день.
Это руководство поможет вам сэкономить много времени, если вы его сохраните, потому что мы выполняли одни и те же задачи по-разному, так что вам больше не придётся искать их в Google.