Python正则表达式错误:在0位置没有重复

时间:2017-09-07 19:27:50

标签: python regex python-3.x

我正在尝试匹配可以从普通英语键盘输入的字符串。

因此,它应包括字母,数字和键盘上的所有符号。

Corresponding regex : "[a-zA-Z0-9\t ./,<>?;:\"'`!@#$%^&*()\[\]{}_+=|\\-]+"

我在regexr.com上验证了这个正则表达式。

在python中,匹配时出现以下错误:

>>> a=re.match("+how to block a website in edge",pattern)

Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "C:\local\Anaconda3-4.1.1-Windows-x86_64\envs\tf_1.2\lib\re.py", line 163, in match
    return _compile(pattern, flags).match(string)
  File "C:\local\Anaconda3-4.1.1-Windows-x86_64\envs\tf_1.2\lib\re.py", line 293, in _compile
    p = sre_compile.compile(pattern, flags)
  File "C:\local\Anaconda3-4.1.1-Windows-x86_64\envs\tf_1.2\lib\sre_compile.py", line 536, in compile
    p = sre_parse.parse(p, flags)
  File "C:\local\Anaconda3-4.1.1-Windows-x86_64\envs\tf_1.2\lib\sre_parse.py", line 829, in parse
    p = _parse_sub(source, pattern, 0)
  File "C:\local\Anaconda3-4.1.1-Windows-x86_64\envs\tf_1.2\lib\sre_parse.py", line 437, in _parse_sub
    itemsappend(_parse(source, state, nested + 1))
  File "C:\local\Anaconda3-4.1.1-Windows-x86_64\envs\tf_1.2\lib\sre_parse.py", line 638, in _parse
    source.tell() - here + len(this))
sre_constants.error: nothing to repeat at position 0

2 个答案:

答案 0 :(得分:4)

你有re.match落后的论据:它应该是

re.match(pattern, "+how to block a website in edge")

答案 1 :(得分:1)

此错误消息与参数的位置无关。是的,上面的问题是顺序不正确,但这只是问题的一半。

当我遇到这样的问题时,我就遇到了这个问题:

re.search('**myword', '/path/to/**myword') 

我想自动获取'**',所以我不想在某个地方手动写'\'。为此,存在re.escape()函数。这是正确的代码:

re.search(re.escape('**myword'), '/path/to/**myword')

这里的问题是在行首之后放置特殊字符。