**Контекст:** Логистическая компания мониторит загрузку 5 складов, чтобы распределять поставки.
**Данные:**
- DataFrame `inventory` — колонки: `sku`, `warehouse_id` (WH1–WH5), `category` (electronics, food, clothing, chemicals), `quantity`, `volume_m3`
- DataFrame `warehouses` — колонки: `warehouse_id`, `capacity_m3`, `city`
**Задание:**
1. Объедините таблицы и рассчитайте занятый объём на каждом складе
2. Постройте pivot-таблицу: склады × категории → объём
3. Рассчитайте % заполненности каждого склада и найдите перегруженные (> 85%)
Структура для ориентира — реальные значения из эталонного решения.
warehouses = pd.DataFrame({
'warehouse_id': ['WH1', 'WH2', 'WH3', 'WH4', 'WH5'],
'capacity_m3': [5000, 3000, 8000, 4500, 6000],
'city': ['Москва', 'СПб', 'Новосибирск', 'Казань', 'Екатеринбург'],
})
pandas groupby pivot_table merge утилизация
Это задание для уровня Junior. Подходит для начинающих аналитиков, проверяет базовые знания SQL/Python/статистики.
Подобные задания в категории «Python» регулярно дают на собеседованиях аналитика данных в Яндекс, Сбер, Ozon, Авито, Тинькофф, Wildberries, T-Bank, X5, ВТБ и других крупных IT-компаниях. Тематика: pandas, groupby, pivot_table, merge, утилизация.
На реальном собеседовании на подобную задачу отводится 5-10 минут — проверяется скорость и базовая грамотность. Для тренировки рекомендуем сначала решить самостоятельно, потом сверить с эталонным решением и подсказками.
На zasqlpython.ru есть 482 Python задачи с проверкой через Pyodide, конспекты Python и pandas, AI мок-собеседование с разбором ваших ответов.
← Все задания