Ну, я нашел способ ее решить, хотя, возможно, не самый элегантный. Как бы вы улучшили это? , на самом деле, я теряю информацию.
Я добавил это:
v=v.replace**("Build a wall and add a new door", "Build a wall and add a new")
Итак, код теперь:
v=pd.Series(['New wiring system for an extra room','Build a wall and add a new door',
'Fix a shelving unit'])
v=v.replace("Build a wall and add a new door", "Build a wall and add a new")
print(v.replace("Build a wall and add a new door", "Build a wall and add a new"))
v=v.str.lower()
print(v)
pattern_cons='ret|wall|ceiling|buil|holes|cons'
pattern_nrg= 'wiring|media|elect'
pattern_plumb='water'
pattern_carp= 'shelving|table|door'
pattern_work=pd.Series([pattern_cons,pattern_nrg,
pattern_plumb, pattern_carp])
# Use this code : (I loop this)
for x in range(4):
pattern=pattern_work
vector={'pattern': pattern_work[x],'type_work':class_str[x]}
print(vector)
s=v.str.contains(vector['pattern'], flags=re.IGNORECASE, regex=True)
print(s)
Теперь я получаю правильный ответ (тот, который я хотел):
0 New wiring system for an extra room
1 Build a wall and add a new
2 Fix a shelving unit
dtype: object
0 new wiring system for an extra room
1 build a wall and add a new
2 fix a shelving unit
dtype: object
{'pattern': 'ret|wall|ceiling|buil|holes|cons', 'type_work': 'cons'}
0 False
1 True
2 False
dtype: bool
{'pattern': 'wiring|media|elect', 'type_work': 'nrg'}
0 True
1 False
2 False
dtype: bool
{'pattern': 'water', 'type_work': 'plumb'}
0 False
1 False
2 False
dtype: bool
{'pattern': 'shelving|table|door', 'type_work': 'carp'}
0 False
1 False
2 True
dtype: bool