как узнать количество столбцов в pandas

Подсчет и фильтрация строк в DataFrame Pandas

Чтобы подсчитать количество строк в DataFrame, вы можете использовать свойство shape или метод count().

DataFrame.shape возвращает кортеж, содержащий количество строк в качестве первого элемента и количество столбцов в качестве второго элемента. Индексируя первый элемент, мы можем получить количество строк в DataFrame.

DataFrame.count() со значениями параметров по умолчанию возвращает количество значений по каждому столбцу. Каждый столбец содержит одинаковое количество значений, равное количеству строк. Индексируя первый элемент, мы можем получить количество строк в DataFrame.

Пример 1: подсчет с помощью shape

В этом примере мы будем использовать свойство DataFrame.shape, чтобы получить количество строк.

Пример 2: с помощью count()

В этом примере мы будем использовать метод count() для подсчета количества строк в DataFrame.

В этом руководстве на примерах Python мы узнали, как подсчитать количество строк в заданном DataFrame разными способами с помощью примеров программ.

Фильтрации строк

Чтобы отфильтровать строки в DataFrame, вы можете использовать функцию isin(). Она возвращает логический DataFrame, который при использовании с исходным фильтрует строки, которые подчиняются критериям фильтра.

Вы также можете использовать query() для фильтрации строк, удовлетворяющих заданному логическому выражению.

Пример 1: с помощью isin()

В этом примере мы возьмем DataFrame с двумя столбцами с именами a, b и четырьмя строками. Мы будем фильтровать при условии, что значения столбца a лежат в заданном диапазоне.

Функция isin() возвращает True для строк, значения столбца в которых находятся в диапазоне (3,6). В противном случае функция возвращает false.

df [out] возвращает только те строки, значение которых равно True, что приводит к отфильтрованному выводу.

Пример 2: с помощью query()

В этом примере мы инициализируем DataFrame двумя столбцами a и b, содержащими четыре строки. Мы будем фильтровать те строки, у которых значение столбца b больше 4.

Мы будем использовать query() для фильтрации строк.

В этом руководстве на примерах Python мы узнали, как фильтровать DataFrame на основе условий, применяемых к значениям его столбцов.

Источник

Моя шпаргалка по pandas

Один преподаватель как-то сказал мне, что если поискать аналог программиста в мире книг, то окажется, что программисты похожи не на учебники, а на оглавления учебников: они не помнят всего, но знают, как быстро найти то, что им нужно.

Возможность быстро находить описания функций позволяет программистам продуктивно работать, не теряя состояния потока. Поэтому я и создал представленную здесь шпаргалку по pandas и включил в неё то, чем пользуюсь каждый день, создавая веб-приложения и модели машинного обучения.

как узнать количество столбцов в pandas. . как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-. картинка как узнать количество столбцов в pandas. картинка .

1. Подготовка к работе

Если вы хотите самостоятельно опробовать то, о чём тут пойдёт речь, загрузите набор данных Anime Recommendations Database с Kaggle. Распакуйте его и поместите в ту же папку, где находится ваш Jupyter Notebook (далее — блокнот).

Теперь выполните следующие команды.

После этого у вас должна появиться возможность воспроизвести то, что я покажу в следующих разделах этого материала.

2. Импорт данных

▍Загрузка CSV-данных

Здесь я хочу рассказать о преобразовании CSV-данных непосредственно в датафреймы (в объекты Dataframe). Иногда при загрузке данных формата CSV нужно указывать их кодировку (например, это может выглядеть как encoding=’ISO-8859–1′ ). Это — первое, что стоит попробовать сделать в том случае, если оказывается, что после загрузки данных датафрейм содержит нечитаемые символы.

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

▍Создание датафрейма из данных, введённых вручную

Это может пригодиться тогда, когда нужно вручную ввести в программу простые данные. Например — если нужно оценить изменения, претерпеваемые данными, проходящими через конвейер обработки данных.

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Данные, введённые вручную

▍Копирование датафрейма

Копирование датафреймов может пригодиться в ситуациях, когда требуется внести в данные изменения, но при этом надо и сохранить оригинал. Если датафреймы нужно копировать, то рекомендуется делать это сразу после их загрузки.

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

3. Экспорт данных

▍Экспорт в формат CSV

При экспорте данных они сохраняются в той же папке, где находится блокнот. Ниже показан пример сохранения первых 10 строк датафрейма, но то, что именно сохранять, зависит от конкретной задачи.

4. Просмотр и исследование данных

▍Получение n записей из начала или конца датафрейма

Сначала поговорим о выводе первых n элементов датафрейма. Я часто вывожу некоторое количество элементов из начала датафрейма где-нибудь в блокноте. Это позволяет мне удобно обращаться к этим данным в том случае, если я забуду о том, что именно находится в датафрейме. Похожую роль играет и вывод нескольких последних элементов.

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Данные из начала датафрейма

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Данные из конца датафрейма

▍Подсчёт количества строк в датафрейме

▍Подсчёт количества уникальных значений в столбце

Для подсчёта количества уникальных значений в столбце можно воспользоваться такой конструкцией:

▍Получение сведений о датафрейме

В сведения о датафрейме входит общая информация о нём вроде заголовка, количества значений, типов данных столбцов.

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Сведения о датафрейме

▍Вывод статистических сведений о датафрейме

Знание статистических сведений о датафрейме весьма полезно в ситуациях, когда он содержит множество числовых значений. Например, знание среднего, минимального и максимального значений столбца rating даёт нам некоторое понимание того, как, в целом, выглядит датафрейм. Вот соответствующая команда:

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Статистические сведения о датафрейме

▍Подсчёт количества значений

Для того чтобы подсчитать количество значений в конкретном столбце, можно воспользоваться следующей конструкцией:

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Подсчёт количества элементов в столбце

5. Извлечение информации из датафреймов

▍Создание списка или объекта Series на основе значений столбца

Это может пригодиться в тех случаях, когда требуется извлекать значения столбцов в переменные x и y для обучения модели. Здесь применимы следующие команды:

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Результаты работы команды anime[‘genre’].tolist()

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Результаты работы команды anime[‘genre’]

▍Получение списка значений из индекса

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Результаты выполнения команды

▍Получение списка значений столбцов

Вот команда, которая позволяет получить список значений столбцов:

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Результаты выполнения команды

6. Добавление данных в датафрейм и удаление их из него

▍Присоединение к датафрейму нового столбца с заданным значением

Иногда мне приходится добавлять в датафреймы новые столбцы. Например — в случаях, когда у меня есть тестовый и обучающий наборы в двух разных датафреймах, и мне, прежде чем их скомбинировать, нужно пометить их так, чтобы потом их можно было бы различить. Для этого используется такая конструкция:

▍Создание нового датафрейма из подмножества столбцов

Это может пригодиться в том случае, если требуется сохранить в новом датафрейме несколько столбцов огромного датафрейма, но при этом не хочется выписывать имена столбцов, которые нужно удалить.

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Результат выполнения команды

▍Удаление заданных столбцов

Этот приём может оказаться полезным в том случае, если из датафрейма нужно удалить лишь несколько столбцов. Если удалять нужно много столбцов, то эта задача может оказаться довольно-таки утомительной, поэтому тут я предпочитаю пользоваться возможностью, описанной в предыдущем разделе.

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Результаты выполнения команды

▍Добавление в датафрейм строки с суммой значений из других строк

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Результат выполнения команды

Команда вида df.sum(axis=1) позволяет суммировать значения в столбцах.

7. Комбинирование датафреймов

▍Конкатенация двух датафреймов

Эта методика применима в ситуациях, когда имеются два датафрейма с одинаковыми столбцами, которые нужно скомбинировать.

В данном примере мы сначала разделяем датафрейм на две части, а потом снова объединяем эти части:

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Датафрейм, объединяющий df1 и df2

▍Слияние датафреймов

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Результаты выполнения команды

8. Фильтрация

▍Получение строк с нужными индексными значениями

Индексными значениями датафрейма anime_modified являются названия аниме. Обратите внимание на то, как мы используем эти названия для выбора конкретных столбцов.

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Результаты выполнения команды

▍Получение строк по числовым индексам

Следующая конструкция позволяет выбрать три первых строки датафрейма:

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Результаты выполнения команды

▍Получение строк по заданным значениям столбцов

Для получения строк датафрейма в ситуации, когда имеется список значений столбцов, можно воспользоваться следующей командой:

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Результаты выполнения команды

Если нас интересует единственное значение — можно воспользоваться такой конструкцией:

▍Получение среза датафрейма

Эта техника напоминает получение среза списка. А именно, речь идёт о получении фрагмента датафрейма, содержащего строки, соответствующие заданной конфигурации индексов.

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Результаты выполнения команды

▍Фильтрация по значению

Из датафреймов можно выбирать строки, соответствующие заданному условию. Обратите внимание на то, что при использовании этого метода сохраняются существующие индексные значения.

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Результаты выполнения команды

9. Сортировка

Для сортировки датафреймов по значениям столбцов можно воспользоваться функцией df.sort_values :

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Результаты выполнения команды

10. Агрегирование

▍Функция df.groupby и подсчёт количества записей

Вот как подсчитать количество записей с различными значениями в столбцах:

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Результаты выполнения команды

▍Функция df.groupby и агрегирование столбцов различными способами

▍Создание сводной таблицы

Для того чтобы извлечь из датафрейма некие данные, нет ничего лучше, чем сводная таблица. Обратите внимание на то, что здесь я серьёзно отфильтровал датафрейм, что ускорило создание сводной таблицы.

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Результаты выполнения команды

11. Очистка данных

▍Запись в ячейки, содержащие значение NaN, какого-то другого значения

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Таблица, содержащая значения NaN

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Результаты замены значений NaN на 0

12. Другие полезные возможности

▍Отбор случайных образцов из набора данных

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Результаты выполнения команды

▍Перебор строк датафрейма

Следующая конструкция позволяет перебирать строки датафрейма:

как узнать количество столбцов в pandas. image loader. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-image loader. картинка как узнать количество столбцов в pandas. картинка image loader.

Результаты выполнения команды

▍Борьба с ошибкой IOPub data rate exceeded

Если вы сталкиваетесь с ошибкой IOPub data rate exceeded — попробуйте, при запуске Jupyter Notebook, воспользоваться следующей командой:

Итоги

Здесь я рассказал о некоторых полезных приёмах использования pandas в среде Jupyter Notebook. Надеюсь, моя шпаргалка вам пригодится.

Источник

панды Python как подсчитать количество записей или строк в таблице данных

очевидно, новый для панд. Как я могу просто подсчитать количество записей в фрейме данных.

Я бы подумал, что такая простая вещь, как это, сделает это, и я даже не могу найти ответ в поисках. наверное, потому, что это слишком просто.

приведенный выше код фактически просто печатает весь df

4 ответов

С уважением к вашему вопросу. считая одно поле? Я решил задать вопрос, но надеюсь, это поможет.

скажем, у меня есть следующий DataFrame

вы можете сосчитать один столбец по

оба оценивают до 5.

классная вещь (или одна из многих w.r.т. pandas ) это если у вас есть NA значения, count принимает это во внимание.

так если бы я сделал

результат будет будь

получить количество строк в таблице данных:

(и df.shape[1] получить количество столбцов).

в качестве альтернативы вы можете использовать

(и len(df.columns) для столбцов)

избежать: count() потому что он возвращает количество наблюдений не-NA / null над запрошенной осью

len(df.index) быстрее

df.__len__ это просто вызов len(df.index)

почему вы не должны использовать count()

просто row_num = df.shape[0] # дает количество строк, вот пример:

пример Nan выше пропускает одну часть, что делает его менее общим. Для этого более «обобщенно» используйте df[‘column_name’].value_counts() Это даст вам количество каждого значения в этом столбце.

Источник

Работа со строками и столбцами в Pandas DataFrame

как узнать количество столбцов в pandas. . как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-. картинка как узнать количество столбцов в pandas. картинка .

Работа с колоннами

Чтобы иметь дело со столбцами, мы выполняем основные операции над столбцами, такие как выбор, удаление, добавление и переименование.
как узнать количество столбцов в pandas. maimealsiborrcatu773136. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-maimealsiborrcatu773136. картинка как узнать количество столбцов в pandas. картинка maimealsiborrcatu773136.

Выбор столбца :
Чтобы выбрать столбец в Pandas DataFrame, мы можем получить доступ к столбцам, вызвав их по имени столбца.

# Импорт пакета панд

import pandas as pd

# Определить словарь, содержащий данные о сотрудниках

# Конвертировать словарь в DataFrame

# выбрать два столбца

Выход:
как узнать количество столбцов в pandas. goldpregavenrasa596118. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-goldpregavenrasa596118. картинка как узнать количество столбцов в pandas. картинка goldpregavenrasa596118.
Дополнительные примеры см. В разделе « Как выбрать несколько столбцов в кадре данных pandas».

Добавление столбца :
Чтобы добавить столбец в Pandas DataFrame, мы можем объявить новый список как столбец и добавить его в существующий Dataframe.

# Импорт пакета панд

import pandas as pd

# Определить словарь, содержащий данные студентов

# Конвертировать словарь в DataFrame

# Объявить список, который должен быть преобразован в столбец

# Использование адреса в качестве имени столбца
# и приравнивая его к списку

df[ ‘Address’ ] = address

Выход:
как узнать количество столбцов в pandas. proteneqglyzinha415986. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-proteneqglyzinha415986. картинка как узнать количество столбцов в pandas. картинка proteneqglyzinha415986.
Дополнительные примеры см. В разделе «Добавление нового столбца в существующий DataFrame в Pandas».

# импорт модуля панд

import pandas as pd

# создание фрейма данных из CSV-файла

# отбрасывание пропущенных столбцов

Выход:
Как показано на выходных изображениях, новый вывод не имеет пропущенных столбцов. Эти значения были отброшены, поскольку ось была установлена равной 1, и изменения были сделаны в исходном фрейме данных, поскольку inplace было True.

Фрейм данных перед удалением столбцов

как узнать количество столбцов в pandas. asbacduleasocoun553505. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-asbacduleasocoun553505. картинка как узнать количество столбцов в pandas. картинка asbacduleasocoun553505.

Кадр данных после удаления столбцов

как узнать количество столбцов в pandas. spanocidchipepi225026. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-spanocidchipepi225026. картинка как узнать количество столбцов в pandas. картинка spanocidchipepi225026.

Работа со строками:

Чтобы иметь дело со строками, мы можем выполнять основные операции над строками, такие как выбор, удаление, добавление и переименование.

# импорт пакета панд

import pandas as pd

# создание фрейма данных из CSV-файла

# извлечение строки методом loc

first = data.loc[ «Avery Bradley» ]

second = data.loc[ «R.J. Hunter» ]

Добавление строки :
Чтобы добавить строку в DataFrame Pandas, мы можем объединить старый dataframe с новым.

# импорт модуля панд

import pandas as pd

# создание фрейма данных

# просто объединить оба кадра данных

df = pd.concat([new_row, df]).reset_index(drop = True )

Фрейм данных перед добавлением строки
как узнать количество столбцов в pandas. viltituchaterswood18736. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-viltituchaterswood18736. картинка как узнать количество столбцов в pandas. картинка viltituchaterswood18736.

Фрейм данных после добавления строки
как узнать количество столбцов в pandas. prolasmanvicube643411. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-prolasmanvicube643411. картинка как узнать количество столбцов в pandas. картинка prolasmanvicube643411.

Удаление строк :
Чтобы удалить строку в Pandas DataFrame, мы можем использовать метод drop (). Строки удаляются путем удаления строк по метке индекса.

# импорт модуля панд

import pandas as pd

# создание фрейма данных из CSV-файла

# отбрасывание пропущенных значений

«R.J. Hunter» ], inplace = True )

Выход:
Как показано на выходных изображениях, новый вывод не имеет переданных значений. Эти значения были отброшены, и изменения были внесены в исходный фрейм данных, поскольку inplace был True.

Кадр данных перед сбросом значений

как узнать количество столбцов в pandas. singbookriaprofwinlins514822. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-singbookriaprofwinlins514822. картинка как узнать количество столбцов в pandas. картинка singbookriaprofwinlins514822.

Фрейм данных после удаления значений

как узнать количество столбцов в pandas. prepilensparotspir408256. как узнать количество столбцов в pandas фото. как узнать количество столбцов в pandas-prepilensparotspir408256. картинка как узнать количество столбцов в pandas. картинка prepilensparotspir408256.

Проблема, связанная с колонками:

Проблема, связанная со строками:

Источник

Аналитикам: большая шпаргалка по Pandas

Привет. Я задумывал эту заметку для студентов курса Digital Rockstar, на котором мы учим маркетологов автоматизировать свою работу с помощью программирования, но решил поделиться шпаргалкой по Pandas со всеми. Я ожидаю, что читатель умеет писать код на Python хотя бы на минимальном уровне, знает, что такое списки, словари, циклы и функции.

Что такое Pandas и зачем он нужен

Pandas — это библиотека для работы с данными на Python. Она упрощает жизнь аналитикам: где раньше использовалось 10 строк кода теперь хватит одной.

Например, чтобы прочитать данные из csv, в стандартном Python надо сначала решить, как хранить данные, затем открыть файл, прочитать его построчно, отделить значения друг от друга и очистить данные от специальных символов.

В Pandas всё проще. Во-первых, не нужно думать, как будут храниться данные — они лежат в датафрейме. Во-вторых, достаточно написать одну команду:

Pandas добавляет в Python новые структуры данных — серии и датафреймы. Расскажу, что это такое.

Структуры данных: серии и датафреймы

Серии — одномерные массивы данных. Они очень похожи на списки, но отличаются по поведению — например, операции применяются к списку целиком, а в сериях — поэлементно.

То есть, если список умножить на 2, получите тот же список, повторенный 2 раза.

А если умножить серию, ее длина не изменится, а вот элементы удвоятся.

Обратите внимание на первый столбик вывода. Это индекс, в котором хранятся адреса каждого элемента серии. Каждый элемент потом можно получать, обратившись по нужному адресу.

Еще одно отличие серий от списков — в качестве индексов можно использовать произвольные значения, это делает данные нагляднее. Представим, что мы анализируем помесячные продажи. Используем в качестве индексов названия месяцев, значениями будет выручка:

Теперь можем получать значения каждого месяца:

Так как серии — одномерный массив данных, в них удобно хранить измерения по одному. На практике удобнее группировать данные вместе. Например, если мы анализируем помесячные продажи, полезно видеть не только выручку, но и количество проданных товаров, количество новых клиентов и средний чек. Для этого отлично подходят датафреймы.

Датафреймы — это таблицы. У их есть строки, колонки и ячейки.

Технически, колонки датафреймов — это серии. Поскольку в колонках обычно описывают одни и те же объекты, то все колонки делят один и тот же индекс:

Объясню, как создавать датафреймы и загружать в них данные.

Создаем датафреймы и загружаем данные

Бывает, что мы не знаем, что собой представляют данные, и не можем задать структуру заранее. Тогда удобно создать пустой датафрейм и позже наполнить его данными.

А иногда данные уже есть, но хранятся в переменной из стандартного Python, например, в словаре. Чтобы получить датафрейм, эту переменную передаем в ту же команду:

Случается, что в некоторых записях не хватает данных. Например, посмотрите на список goods_sold — в нём продажи, разбитые по товарным категориям. За первый месяц мы продали машины, компьютеры и программное обеспечение. Во втором машин нет, зато появились велосипеды, а в третьем снова появились машины, но велосипеды исчезли:

Если загрузить данные в датафрейм, Pandas создаст колонки для всех товарных категорий и, где это возможно, заполнит их данными:

Обратите внимание, продажи велосипедов в первом и третьем месяце равны NaN — расшифровывается как Not a Number. Так Pandas помечает отсутствующие значения.

Теперь разберем, как загружать данные из файлов. Чаще всего данные хранятся в экселевских таблицах или csv-, tsv- файлах.

Файлы формата csv и tsv — это текстовые файлы, в которых данные отделены друг от друга запятыми или табуляцией:

После загрузки данных в датафрейм, хорошо бы их исследовать — особенно, если они вам незнакомы.

Исследуем загруженные данные

В датафрейме 5009 строк и 5 колонок.

Теперь видим, что в таблице есть дата заказа, метод доставки, номер клиента и выручка.

Тип object — это текст, float64 — это дробное число типа 3,14.

Ожидаемо, в индексе датафрейма номера заказов: 100762, 100860 и так далее.

Получив первое представление о датафреймах, теперь обсудим, как доставать из него данные.

Получаем данные из датафреймов

Данные из датафреймов можно получать по-разному: указав номера колонок и строк, использовав условные операторы или язык запросов. Расскажу подробнее о каждом способе.

Указываем нужные строки и колонки

Обратите внимание, результат команды — новый датафрейм с таким же индексом.

Можно фильтровать датафреймы по колонкам и столбцам одновременно:

Часто вы не знаете заранее номеров заказов, которые вам нужны. Например, если задача — получить заказы, стоимостью более 1000 рублей. Эту задачу удобно решать с помощью условных операторов.

Если — то. Условные операторы

Задача: нужно узнать, откуда приходят самые большие заказы. Начнем с того, что достанем все покупки стоимостью более 1000 долларов:

Интересно, сколько дорогих заказов было доставлено первым классом? Добавим в фильтр ещё одно условие:

Язык запросов

Разобравшись, как получать куски данных из датафрейма, перейдем к тому, как считать агрегированные метрики: количество заказов, суммарную выручку, средний чек, конверсию.

Считаем производные метрики

Другое дело. Теперь видим сумму выручки по каждому классу доставки. По суммарной выручке неясно, становится лучше или хуже. Добавим разбивку по датам заказа:

Ого, получается, что это так прыгает средний чек. Интересно, а какой был самый удачный день? Чтобы узнать, отсортируем получившийся датафрейм: выведем 10 самых денежных дней по выручке:

Команда разрослась, и её теперь неудобно читать. Чтобы упростить, можно разбить её на несколько строк. В конце каждой строки ставим обратный слеш \ :

В самый удачный день — 18 марта 2014 года — магазин заработал 27 тысяч долларов с помощью стандартного класса доставки. Интересно, откуда были клиенты, сделавшие эти заказы? Чтобы узнать, надо объединить данные о заказах с данными о клиентах.

Объединяем несколько датафреймов

До сих пор мы смотрели только на таблицу с заказами. Но ведь у нас есть еще данные о клиентах интернет-магазина. Загрузим их в переменную customers и посмотрим, что они собой представляют:

Решаем задачу

Закрепим полученный материал, решив задачу. Найдем 5 городов, принесших самую большую выручку в 2016 году.

Для начала отфильтруем заказы из 2016 года:

Город — это атрибут пользователей, а не заказов. Добавим информацию о пользователях:

Cруппируем получившийся датафрейм по городам и посчитаем выручку:

Отсортируем по убыванию продаж и оставим топ-5:

Возьмите данные о заказах и покупателях и посчитайте:

Через некоторое время выложу ответы в Телеграме. Подписывайтесь, чтобы не пропустить ответы и новые статьи.

Кстати, большое спасибо Александру Марфицину за то, что помог отредактировать статью.

Источник

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *