如果只取元组的第一个值,重新格式化元组列表时会出现问题?

2024-05-13 09:36:04 发布

您现在位置:Python中文网/ 问答频道 /正文

我有以下元组列表:

>>>lis = df['vals'].values.tolist()
>>>lis
[[('apple', 'FRUIT'),
          ('$', 'SYM'),
          ('6.00', 'X'),
          ('bannana', 'FRUIT'),
          ('$', 'SYM'),
          ('4.00', 'X')]]

如何将其重新格式化为:

lis = [['apple: $ 6.00', 'bannana: $ 4.00']]

我试着:

list_comp = [item for sublist in lis for item in sublist]
list_comp = [' '.join(item) for t in list_comp for item in [t]]

但是,我不知道如何将:和上面的格式。你知道吗


Tags: inappledf列表foritemlist元组
2条回答

您可以使用理解并将": $ "与元组元素连接起来:

print [lis[0][i][0] + ": $ " + lis[0][i+2][0] for i in range(0,len(lis[0]),3)]

首先,定义一个函数:

>>> def format_tuple(fruit, sym, x):
...   return "{}: {} {}".format(fruit, sym, x)
... 

那么

>>> my_list
[[('apple', 'FRUIT'), ('$', 'SYM'), ('6.00', 'X'), ('bannana', 'FRUIT'), ('$', 'SYM'), ('4.00', 'X')]]
>>> my_list = my_list[0]
>>> by_three = (my_list[i:i + 3] for i in range(0,len(my_list), 3))
>>> [format_tuple(*(c[0] for c in chunk)) for chunk in by_three]
['apple: $ 6.00', 'bannana: $ 4.00']

如果你真的想把它包装成一个列表,最后一行可以是:

>>> [[format_tuple(*(c[0] for c in chunk)) for chunk in by_three]]
[['apple: $ 6.00', 'bannana: $ 4.00']]

相关问题 更多 >