在pandas列中提取列表的元素 [英] Extracting an element of a list in a pandas column
问题描述
我有一个DataFrame,在每个列上都包含一个列表,如下面的示例所示,只有两列.
I have a DataFrame that contains a list on each column as shown in the example below with only two columns.
Gamma Beta
0 [1.4652917656926299, 0.9326935235505321, float] [91, 48.611034768515864, int]
1 [2.6008354611105995, 0.7608529935313189, float] [59, 42.38646954167245, int]
2 [2.6386970166722348, 0.9785848171888037, float] [89, 37.9011122659478, int]
3 [3.49336632573625, 1.0411524946972244, float] [115, 36.211134224288344, int]
4 [2.193991200007534, 0.7955134305428825, float] [128, 50.03563864975485, int]
5 [3.4574527664490997, 0.9399880977511021, float] [120, 41.841146628802875, int]
6 [3.1190582380554863, 1.0839109431114795, float] [148, 55.990072419824514, int]
7 [2.7757359940789916, 0.8889801332053203, float] [142, 51.08885697101243, int]
8 [3.23820908493237, 1.0587479742892683, float] [183, 43.831293356668425, int]
9 [2.2509032790941985, 0.8896196407231622, float] [66, 35.9377662201882, int]
我想为每一列提取列表在每一行上的第一位置,以得到一个如下所示的DataFrame.
I'd like to extract for every column the first position of the list on each row to get a DataFrame looking as follows.
Gamma Beta
0 1.4652917656926299 91
1 2.6008354611105995 59
2 2.6386970166722348 89
...
到目前为止,我的解决方案就像[row[1][0] for row in df_params.itertuples()]
,可以对行的每个列索引进行迭代,然后编写新的DataFrame.
Up to now, my solution would be like [row[1][0] for row in df_params.itertuples()]
, which I could iterate for every column index of the row and then compose my new DataFrame.
另一个选择是new_df = df_params['Gamma'].apply(lambda x: x[0])
,然后迭代遍历所有列.
An alternative is new_df = df_params['Gamma'].apply(lambda x: x[0])
and then to iterate to go through all the columns.
我的问题是,执行此操作是否比较麻烦?
My question is, is there a less cumbersome way to perform this operation?
推荐答案
您可以将str
访问器用于列表,例如:
You can use the str
accessor for lists, e.g.:
df_params['Gamma'].str[0]
这应该适用于所有列:
df_params.apply(lambda col: col.str[0])
这篇关于在pandas列中提取列表的元素的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!