我对regex很陌生,python。例如,我的字符串列表是:
my_try = ['Aas','1Aasdf','cc)','ASD','.ASD','aaaa1','A']
现在,我想删除所有非英文字母的字符串。所以,我只想保持:
['Aas','ASD','A']
我不知道怎么用^或别的什么来做这个?有人能帮我吗?
如果我的数据是:
my_try=pd.DataFrame({'try':
['Aas','1Aasdf','cc)','A2SD','.ASD',
'aaaa1','A','123%']})
然后我使用:
[x for x in my_try if re.match(r'^[a-zA-Z]+$', x['try'])]
为什么我会犯这样的错误:
Traceback (most recent call last):
File "C:\feng\myCode\infoExtract\venv\lib\site-packages\IPython \core\interactiveshell.py", line 3319, in run_code
exec(code_obj, self.user_global_ns, self.user_ns)
File "", line 1, in
[x for x in my_try if re.match(r'^[a-zA-Z]+$', x['try'])]
File "", line 1, in
[x for x in my_try if re.match(r'^[a-zA-Z]+$', x['try'])]
TypeError: string indices must be integers
有谁能告诉我怎么解决这个问题,为什么会这样?