Pandas - 获取熊猫数据框列括号内的值
Pandas - Get values within parentheses of a panda dataframe column
我的 df
有 2 列:
Name Attr
a(bc)
b(aca)
(cba)
我希望 Attr
列的值在 Name
列的括号内
Name Attr
a(bc) bc
b(aca) aca
(cba) cba
我试过了:
df['Attr'] = re.findall('\(.*?\)',df['Name'].astype('str'))
TypeError: expected string or buffer
非常感谢任何帮助
使用str.extract
:
df['Attr'] = df['Name'].str.extract(r"\(([A-Za-z]+)\)", expand=False)
print (df)
Name Attr
0 a(bc) bc
1 b(aca) aca
2 (cba) cba
或将 ()
添加到您的 regex
:
df['Attr'] = df['Name'].str.extract(r"\((.*?)\)", expand=False)
print (df)
Name Attr
0 a(bc) bc
1 b(aca) aca
2 (cba) cba
我的 df
有 2 列:
Name Attr
a(bc)
b(aca)
(cba)
我希望 Attr
列的值在 Name
Name Attr
a(bc) bc
b(aca) aca
(cba) cba
我试过了:
df['Attr'] = re.findall('\(.*?\)',df['Name'].astype('str'))
TypeError: expected string or buffer
非常感谢任何帮助
使用str.extract
:
df['Attr'] = df['Name'].str.extract(r"\(([A-Za-z]+)\)", expand=False)
print (df)
Name Attr
0 a(bc) bc
1 b(aca) aca
2 (cba) cba
或将 ()
添加到您的 regex
:
df['Attr'] = df['Name'].str.extract(r"\((.*?)\)", expand=False)
print (df)
Name Attr
0 a(bc) bc
1 b(aca) aca
2 (cba) cba