首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >具有特殊字符"(*)“的str.replace

具有特殊字符"(*)“的str.replace
EN

Stack Overflow用户
提问于 2022-04-21 16:37:45
回答 1查看 77关注 0票数 0

我在dataframe中有一些列,在一些数据头上有(*)。当我这么做

代码语言:javascript
复制
data.columns = data.columns.str.replace('(*)','')

我得到以下错误。

代码语言:javascript
复制
  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

我能做什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-04-21 16:43:49

str.replace接受一个正则表达式,*是它试图解释的元字符。试着像这样逃离它:

代码语言:javascript
复制
data.columns.str.replace('(\*)', '')

或者指示您没有使用regex:

代码语言:javascript
复制
data.columns.str.replace('(*)', '', regex=False)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71957962

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档