Python中正则表达式re.match的用法

re.match(pattern, string, flags)
第一个参数是正则表达式,如果匹配成功,则返回一个Match,否则返回一个None;
第二个参数表示要匹配的字符串;
第三个参数是标致位,用于控制正则表达式的匹配方式,如:是否区分大小写,多行匹配等等。
需要特别注意的是,这个方法并不是完全匹配。它仅仅决定在字符串开始的位置是否匹配。所以当pattern结束时若还有剩余字符,仍然视为成功。想要完全匹配,可以在表达式末尾加上边界匹配符'$'
例如: match(‘p’,’python’)返回值为真;
      match(‘p’,’www.python.org’)返回值为假。

再看一个例子,接收用户输入的内容,如果是数字的话将其转为二进制格式,如果不是则给予提示。

如何写正则表达式?

如果写成[0-9]+,则re.match的时候,只要开头是数字的内容都会匹配成功:

例如:match('[0-9]+','1abc')是匹配成功的。

所以必须要加上边界符,写成'[0-9]+$'去进行匹配:

例如: match('[0-9]+$','1abc')这样就不能匹配成功了,必须全部都是数字才可以。

以下是完整源代码:

from re import match
r='[0-9]+$'
s = input('num:')
if match(r,s):
   
    print('数字')
    s = int(s)
    code = ''
    while s!=0:
        code += str(s%2)
        s = s//2
    print(code[::-1])
   
else:
    print('非数字')

猜你喜欢

转载自blog.csdn.net/piglite/article/details/81121323