pandas 数据框:从整个数据框的所有单元格值中添加和删除 prefix/suffix
pandas dataframe : add & remove prefix/suffix from all cell values of entire dataframe
要将 prefix/suffix 添加到数据框,我通常会执行以下操作..
比如要加后缀'@'
,
df = df.astype(str) + '@'
这基本上已将 '@'
添加到所有单元格值。
我想知道如何去掉这个后缀。
pandas.DataFrame class 是否有一种方法可以直接从整个 DataFrame 中删除特定的 prefix/suffix 字符?
我尝试在使用 rstrip('@')
的同时遍历行(作为系列),如下所示:
for index in range(df.shape[0]):
row = df.iloc[index]
row = row.str.rstrip('@')
现在,为了使数据帧脱离这个系列,
new_df = pd.DataFrame(columns=list(df))
new_df = new_df.append(row)
但是,这不起作用。
给出空数据框。
我是否缺少一些非常基本的东西?
可以使用apply
和pd.Series的str.strip
方法:
In [13]: df
Out[13]:
a b c
0 dog quick the
1 lazy lazy fox
2 brown quick dog
3 quick the over
4 brown over lazy
5 fox brown quick
6 quick fox the
7 dog jumped the
8 lazy brown the
9 dog lazy the
In [14]: df = df + "@"
In [15]: df
Out[15]:
a b c
0 dog@ quick@ the@
1 lazy@ lazy@ fox@
2 brown@ quick@ dog@
3 quick@ the@ over@
4 brown@ over@ lazy@
5 fox@ brown@ quick@
6 quick@ fox@ the@
7 dog@ jumped@ the@
8 lazy@ brown@ the@
9 dog@ lazy@ the@
In [16]: df = df.apply(lambda S:S.str.strip('@'))
In [17]: df
Out[17]:
a b c
0 dog quick the
1 lazy lazy fox
2 brown quick dog
3 quick the over
4 brown over lazy
5 fox brown quick
6 quick fox the
7 dog jumped the
8 lazy brown the
9 dog lazy the
请注意,您的方法不起作用,因为当您在 for 循环中执行以下分配时:
row = row.str.rstrip('@')
这只是将 row.str.strip
的结果分配给名称 row
,而不改变 DataFrame
。这是所有 python 对象和简单名称分配的相同行为:
In [18]: rows = [[1,2,3],[4,5,6],[7,8,9]]
In [19]: print(rows)
[[1, 2, 3], [4, 5, 6], [7, 8, 9]]
In [20]: for row in rows:
...: row = ['look','at','me']
...:
In [21]: print(rows)
[[1, 2, 3], [4, 5, 6], [7, 8, 9]]
要真正更改底层数据结构,您需要使用修改器方法:
In [22]: rows
Out[22]: [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
In [23]: for row in rows:
...: row.append("LOOKATME")
...:
In [24]: rows
Out[24]: [[1, 2, 3, 'LOOKATME'], [4, 5, 6, 'LOOKATME'], [7, 8, 9, 'LOOKATME']]
请注意,切片赋值只是增变器方法的语法糖:
In [26]: rows
Out[26]: [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
In [27]: for row in rows:
...: row[:] = ['look','at','me']
...:
...:
In [28]: rows
Out[28]: [['look', 'at', 'me'], ['look', 'at', 'me'], ['look', 'at', 'me']]
这类似于基于 pandas
loc
或 iloc
的赋值。
您可以使用 applymap 将您的字符串方法应用于每个元素:
df = df.applymap(lambda x: str(x).rstrip('@'))
注意:我不认为这会像矢量化方法一样快:pd.Series.str.rstrip
即分别转换每一列
您可以使这变得非常简单,只需使用 pandas.DataFrame.replace() 方法将所有“@”替换为“”:
df.replace("@", "")
如果您担心“@”不仅在您的值的末尾被替换,您可以使用正则表达式:
df.replace("@$", "", regex=True)
要将 prefix/suffix 添加到数据框,我通常会执行以下操作..
比如要加后缀'@'
,
df = df.astype(str) + '@'
这基本上已将 '@'
添加到所有单元格值。
我想知道如何去掉这个后缀。 pandas.DataFrame class 是否有一种方法可以直接从整个 DataFrame 中删除特定的 prefix/suffix 字符?
我尝试在使用 rstrip('@')
的同时遍历行(作为系列),如下所示:
for index in range(df.shape[0]):
row = df.iloc[index]
row = row.str.rstrip('@')
现在,为了使数据帧脱离这个系列,
new_df = pd.DataFrame(columns=list(df))
new_df = new_df.append(row)
但是,这不起作用。 给出空数据框。
我是否缺少一些非常基本的东西?
可以使用apply
和pd.Series的str.strip
方法:
In [13]: df
Out[13]:
a b c
0 dog quick the
1 lazy lazy fox
2 brown quick dog
3 quick the over
4 brown over lazy
5 fox brown quick
6 quick fox the
7 dog jumped the
8 lazy brown the
9 dog lazy the
In [14]: df = df + "@"
In [15]: df
Out[15]:
a b c
0 dog@ quick@ the@
1 lazy@ lazy@ fox@
2 brown@ quick@ dog@
3 quick@ the@ over@
4 brown@ over@ lazy@
5 fox@ brown@ quick@
6 quick@ fox@ the@
7 dog@ jumped@ the@
8 lazy@ brown@ the@
9 dog@ lazy@ the@
In [16]: df = df.apply(lambda S:S.str.strip('@'))
In [17]: df
Out[17]:
a b c
0 dog quick the
1 lazy lazy fox
2 brown quick dog
3 quick the over
4 brown over lazy
5 fox brown quick
6 quick fox the
7 dog jumped the
8 lazy brown the
9 dog lazy the
请注意,您的方法不起作用,因为当您在 for 循环中执行以下分配时:
row = row.str.rstrip('@')
这只是将 row.str.strip
的结果分配给名称 row
,而不改变 DataFrame
。这是所有 python 对象和简单名称分配的相同行为:
In [18]: rows = [[1,2,3],[4,5,6],[7,8,9]]
In [19]: print(rows)
[[1, 2, 3], [4, 5, 6], [7, 8, 9]]
In [20]: for row in rows:
...: row = ['look','at','me']
...:
In [21]: print(rows)
[[1, 2, 3], [4, 5, 6], [7, 8, 9]]
要真正更改底层数据结构,您需要使用修改器方法:
In [22]: rows
Out[22]: [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
In [23]: for row in rows:
...: row.append("LOOKATME")
...:
In [24]: rows
Out[24]: [[1, 2, 3, 'LOOKATME'], [4, 5, 6, 'LOOKATME'], [7, 8, 9, 'LOOKATME']]
请注意,切片赋值只是增变器方法的语法糖:
In [26]: rows
Out[26]: [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
In [27]: for row in rows:
...: row[:] = ['look','at','me']
...:
...:
In [28]: rows
Out[28]: [['look', 'at', 'me'], ['look', 'at', 'me'], ['look', 'at', 'me']]
这类似于基于 pandas
loc
或 iloc
的赋值。
您可以使用 applymap 将您的字符串方法应用于每个元素:
df = df.applymap(lambda x: str(x).rstrip('@'))
注意:我不认为这会像矢量化方法一样快:pd.Series.str.rstrip
即分别转换每一列
您可以使这变得非常简单,只需使用 pandas.DataFrame.replace() 方法将所有“@”替换为“”:
df.replace("@", "")
如果您担心“@”不仅在您的值的末尾被替换,您可以使用正则表达式:
df.replace("@$", "", regex=True)