2.7 最短匹配模式

    这个问题一般出现在需要匹配一对分隔符之间的文本的时候(比如引号包含的字符串)。为了说明清楚,考虑如下的例子:

    为了修正这个问题,可以在模式中的*操作符后面加上?修饰符,就像这样:

    1. >>> str_pat.findall(text2)
    2. >>>

    这一节展示了在写包含点(.)字符的正则表达式的时候遇到的一些常见问题。在一个模式字符串中,点(.)匹配除了换行外的任何字符。然而,如果你将点(.)号放在开始与结束符(比如引号)之间的时候,那么匹配操作会查找符合模式的最长可能匹配。这样通常会导致很多中间的被开始与结束符包含的文本被忽略掉,并最终被包含在匹配结果字符串中返回。通过在 或者 这样的操作符后面添加一个 可以强制匹配算法改成寻找最短的可能匹配。