KonstantinKlepikov / rlttest

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

RLT test task

Тестовое задание junior python developer

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

На обычном языке пример задачи выглядит следующим образом: “Необходимо посчитать суммы всех выплат с {28.02.2022} по {31.03.2022}, единица группировки - {день}”.

Ваш алгоритм должен принимать на вход:

  • Дату и время старта агрегации в ISO формате (далее dt_from)
  • Дату и время окончания агрегации в ISO формате (далее dt_upto)
  • Тип агрегации (далее group_type). Типы агрегации могут быть следующие: hour, day, month. То есть группировка всех данных за час, день, неделю, месяц.

Пример входных данных:

{
"dt_from":"2022-09-01T00:00:00",
"dt_upto":"2022-12-31T23:59:00",
"group_type":"month"
}

Комментарий к входным данным: вам необходимо агрегировать выплаты с 1 сентября 2022 года по 31 декабря 2022 года, тип агрегации по месяцу

На выходе ваш алгоритм формирует ответ содержащий:

  • Агрегированный массив данных (далее dataset)
  • Подписи к значениям агрегированного массива данных в ISO формате (далее labels)

Пример ответа:

{
    "dataset": [5906586, 5515874, 5889803, 6092634],
    "labels": [
        "2022-09-01T00:00:00", "2022-10-01T00:00:00",
        "2022-11-01T00:00:00", "2022-12-01T00:00:00"
            ]
        }

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

About


Languages

Language:Python 89.7%Language:Dockerfile 5.0%Language:Shell 2.8%Language:Makefile 2.6%