Создайте фрейм данных Polars из dict (с ключами и значениями, являющимися отдельными столбцами)Python

Программы на Python
Ответить
Anonymous
 Создайте фрейм данных Polars из dict (с ключами и значениями, являющимися отдельными столбцами)

Сообщение Anonymous »

У меня есть следующий код

Код: Выделить всё

import polars as pl

mapping = {
'CASH':  {'qty':  1, 'origin': 'E'},
'ITEM':  {'qty': -9, 'origin': 'A'},
'CHECK': {'qty': 46, 'origin': 'A'},
}

df = pl.DataFrame([{'type': k} | v for k, v in mapping.items()])\
.with_columns(pl.struct(['qty', 'origin']).alias('mapping'))\
.select(pl.col(['type', 'mapping']))
Таким образом, ключи словаря должны стать новым столбцом с именем type, а значения словаря должны находиться в отдельном столбце сопоставления. Моя приведенная выше реализация работает, и df выглядит так:

Код: Выделить всё

shape: (3, 2)
┌───────┬───────────┐
│ type  ┆ mapping   │
│ ---   ┆ ---       │
│ str   ┆ struct[2] │
╞═══════╪═══════════╡
│ CASH  ┆ {1,"E"}   │
│ ITEM  ┆ {-9,"A"}  │
│ CHECK ┆ {46,"A"}  │
└───────┴───────────┘
Но моя реализация очень длинная и выглядит не очень эффективной. Есть ли более идиоматический полярный способ создания этого кадра данных?

Подробнее здесь: https://stackoverflow.com/questions/788 ... wn-columns
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Python»