У меня есть фрейм данных Spark, созданный в Google Analytics, который выглядит следующим образом:
id customDimensions (Array<Struct>)
100 [ {"index": 1, "value": "Earth"}, {"index": 2, "value": "Europe"}]
101 [ {"index": 1, "value": "Mars" }]
У меня также есть фрейм данных "метаданные пользовательских измерений", который выглядит следующим образом:
index name
1 planet
2 continent
Я бы использовал индексы в метаданных df для расширения моих пользовательских измерений в столбцы.Результат должен выглядеть следующим образом:
id planet continent
100 Earth Europe
101 Mars null
Я попробовал следующий подход, и он отлично работает, однако он крайне неэффективен.Я хотел бы знать, есть ли лучший подход.
# Select the two relevant columns
cd = df.select('id', 'customDimensions')
# Explode customDimensions so that each row now has a {index, value}
cd = cd.withColumn('customDimensions', F.explode(cd.customDimensions))
# Put the index and value into their own columns
cd = cd.select('id', 'customDimensions.index', 'customDimensions.value')
# Join with metadata to obtain the name from the index
metadata = metadata.select('index', 'name')
cd = (cd
.join(metadata, cd.index == metadata.index, 'left')
.drop(metadata.index))
# Pivot cd so that each row has the id, and we have columns for each custom dimension
piv = cd.groupBy('id').pivot('name').agg(F.first(F.col('value')))
# Join back to restore the other columns
return df.join(piv, df.id == piv.id).drop(piv.id)
Допущения:
- Существует до 250 пользовательских индексов измерений, и имена известны толькочерез фрейм метаданных
- В оригинальном фрейме данных есть несколько других столбцов, которые я хотел бы сохранить (следовательно, соединение в конце моего решения)