[英]If condition in matching strings(REGEX) in panda with Python
我只想在正则表达式匹配之前添加一个 if 条件:首先我定义正则表达式并将值存储在 Name 中,然后我打印 Name 值。 结果是 True 和 False(布尔值)。
Name = df['Name'].str.match('^(\w+\s*)$')
#If the result matches True value passed and else the value will be False
print(Name)
结果
:
True
False
True
下面的代码是关于我拥有的 if 条件。 我不知道如何将 if 条件与正则表达式匹配。 似乎没有在 if 条件中检查 Name 的值为 True/False 的值。
if Name is True:
print(Name)
else:
print('bye')
代码结果:
bye
预期结果:
John
Saher
谢谢
您可以使用
df.loc[df['Name'].str.match(r'^\w+\s*$')]
注意:你不需要与作为参数传递给正则表达式捕获组Series.str.match
,只需要extract
/ extractall
。
如果您想允许任何数量的前导空白字符,您还可以在^
之后添加\\s*
并使用r'^\\s*\\w+\\s*$'
。
熊猫测试:
import pandas as pd
df = pd.DataFrame({'Name': ['John', '---', 'Saher']})
>>> df.loc[df['Name'].str.match('^(\w+\s*)$')]
Name
0 John
2 Saher
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.