Понимаете, почему то, что вы делаете, не работает. Во-первых, вы пытаетесь получить целое число из типа строки , результат вашей коллекции будет таким:
>>> mvv_list = mvv_count_df.select('mvv').collect()
>>> mvv_list[0]
Out: Row(mvv=1)
Если взять что-то вроде этого:
>>> firstvalue = mvv_list[0].mvv
Out: 1
Вы получите mvv
ценность. Если вам нужна вся информация о массиве, вы можете взять что-то вроде этого:
>>> mvv_array = [int(row.mvv) for row in mvv_list.collect()]
>>> mvv_array
Out: [1,2,3,4]
Но если вы попробуете то же самое для другого столбца, вы получите:
>>> mvv_count = [int(row.count) for row in mvv_list.collect()]
Out: TypeError: int() argument must be a string or a number, not 'builtin_function_or_method'
Это происходит потому, что count
это встроенный метод. И столбец имеет то же имя, что и count
. Чтобы решить эту проблему, измените имя столбца count
на _count
:
>>> mvv_list = mvv_list.selectExpr("mvv as mvv", "count as _count")
>>> mvv_count = [int(row._count) for row in mvv_list.collect()]
Но это обходное решение не требуется, поскольку вы можете получить доступ к столбцу, используя синтаксис словаря:
>>> mvv_array = [int(row['mvv']) for row in mvv_list.collect()]
>>> mvv_count = [int(row['count']) for row in mvv_list.collect()]
И наконец-то заработает!
list(df.select('mvv').toPandas()['mvv'])
. Arrow был интегрирован в PySpark, чтоtoPandas
значительно ускорилось . Не используйте другие подходы, если вы используете Spark 2.3+. См. Мой ответ для получения дополнительных сведений о тестировании.