我在dataframe中有一些列,在一些数据头上有(*)。当我这么做
data.columns = data.columns.str.replace('(*)','')我得到以下错误。
File "C:\Users\ED397JT\Anaconda3\lib\site-packages\pandas\core\strings\object_array.py", line 156, in _str_replace
pat = re.compile(pat, flags=flags)
File "C:\Users\ED397JT\Anaconda3\lib\re.py", line 252, in compile
return _compile(pattern, flags)
File "C:\Users\ED397JT\Anaconda3\lib\re.py", line 304, in _compile
p = sre_compile.compile(pattern, flags)
File "C:\Users\ED397JT\Anaconda3\lib\sre_compile.py", line 764, in compile
p = sre_parse.parse(p, flags)
File "C:\Users\ED397JT\Anaconda3\lib\sre_parse.py", line 948, in parse
p = _parse_sub(source, state, flags & SRE_FLAG_VERBOSE, 0)
File "C:\Users\ED397JT\Anaconda3\lib\sre_parse.py", line 443, in _parse_sub
itemsappend(_parse(source, state, verbose, nested + 1,
File "C:\Users\ED397JT\Anaconda3\lib\sre_parse.py", line 834, in _parse
p = _parse_sub(source, state, sub_verbose, nested + 1)
File "C:\Users\ED397JT\Anaconda3\lib\sre_parse.py", line 443, in _parse_sub
itemsappend(_parse(source, state, verbose, nested + 1,
File "C:\Users\ED397JT\Anaconda3\lib\sre_parse.py", line 668, in _parse
raise source.error("nothing to repeat",
error: nothing to repeat我能做什么?
发布于 2022-04-21 16:43:49
str.replace接受一个正则表达式,*是它试图解释的元字符。试着像这样逃离它:
data.columns.str.replace('(\*)', '')或者指示您没有使用regex:
data.columns.str.replace('(*)', '', regex=False)https://stackoverflow.com/questions/71957962
复制相似问题