美文网首页
17作 正则表达式

17作 正则表达式

作者: 大黄蜂人工智能 | 来源:发表于2018-09-11 20:55 被阅读0次
    1. 写一个正则表达式判断一个字符串是否是ip地址
      规则:一个ip地址由4个数字组成,每个数字之间用.连接。每个数字的大小是0-255

    255.189.10.37 正确
    256.189.89.9 错误

    关键是:写一个正则匹配0-255
    0-9:\d
    10-99:[1-9]\d
    100-199:1\d{2}
    200-249:2[0-4]\d
    250-255:25[0-5]
    0-255: \d|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5]
    x.x.x.x
    (\d|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5]\.){3}(\d|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5])
    
    re_str = r'((\d|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5])\.){3}(\d|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5])'
    str1 = '250.78.78.10'
    if re.fullmatch(re_str, str1):
        print('是IP地址')
    else:
        print('不是IP地址')
    
    1. 计算一个字符串中所有的数字的和
      例如:字符串是:‘hello90abc 78sjh12.5’ 结果是90+78+12.5 = 180.5
    import re
    num=0
    str = 'hello90abc 78sjh12.5'
    re_str = r'[1-9][0-9][.][0-9]|[1-9][0-9]'
    result=re.search(re_str,str)
    while result:
    
        print(result.group())
    
        a = result.group()
    
        num = float(a)+num
    
        end = result.end()
    
        str = str[end:]
    
        result = re.search(re_str,str)
    print(num)
    

    老师方法:

    re_str = r'[+-]?\d+\.\d+|[+-]?\d+'
    all_number = re.findall(re_str, 'h+10ello90abc 78sjh12.5')
    sum1 = 0
    for num_str in all_number:
        sum1 += float(num_str)
    print(sum1)
    
    1. 验证输入的内容只能是汉字
    str1 = input('请输入汉字:')
    # re_str = r'[一-鿋]+'
    re_str = r'[\u4E00-\u9FA5]+'
    if re.fullmatch(re_str, str1):
        print('全是汉字')
    else:
        print('不全是汉字')
    
    1. 电话号码的验证
    phone = input('请输入电话号码')
    re_str = '1[0-9]{10}|[0-9]{4}-[0-9]{7}'
    result = fullmatch(re_str,phone)
    print(result)
    if result != None:
        print('输入正确')
    else:
        print('输入错误')
    
    1. 简单的身份证号的验证
      方法;
      1.前六位是数字: \d{6}
      2.八位是年月日:
      年:1900-2018 ---- 1900-1999:19\d{2}
      2000-2009:200\d
      2010-2018:201[0-8]
      月:00-12:01-09:0[1-9]
      10-12:1[0-2]

    日:00-31:01-09:0[1-9]
    10-29: [1-2]\d
    30-31:3[01]

    3.三位数字: \d{3}
    4.最后一位是数字或者是X: [\dXx]

    \d{6}(19\d{2}|200\d|201[0-8])(0[1-9]|1[0-2])(0[1-9]|[1-2]\d|3[01])\d{3}[\dXx]
    """
    # re_str = r'(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)'
    re_str = r'\d{6}(19\d{2}|200\d|201[0-8])(0[1-9]|1[0-2])(0[1-9]|[1-2]\d|3[01])\d{3}[\dXx]'
    if re.fullmatch(re_str, '500234200004238767'):
        print('是合格的身份证号!')
    else:
        print('不是合格的身份证号!')
    

    二、不定项选择题

    1. 能够完全匹配字符串“(010)-62661617”和字符串“01062661617”的正则表达式包括(A.B.D )

    A. “(?\d{3})?-?\d{8}”
    B. “[0-9()-]+”
    C. “[0-9(-)]\d
    D. “[(]?\d[)-]\d*”

    1. 能够完全匹配字符串“c:\rapidminer\lib\plugs”的正则表达式包括(B.C. )
      A. “c:\rapidminer\lib\plugs”
      B. “c:\rapidminer\lib\plugs”
      C. “(?i)C:\RapidMiner\Lib\Plugs” ?i:将后面的内容的大写变成小写
      D. “(?s)C:\RapidMiner\Lib\Plugs” ?s:单行匹配

    2. 能够完全匹配字符串“back”和“back-end”的正则表达式包括(A.C.D )
      A. “\w{4}-\w{3}|\w{4}” match->back,back-end fullmatch-> back,back-end
      B. “\w{4}|\w{4}-\w{3}” match-> back, back fullmatch-> back,back-end
      C. “\S+-\S+|\S+”
      D. “\w\b-\b\w|\w*”

    3. 能够完全匹配字符串“go go”和“kitty kitty”,但不能完全匹配“go kitty”的正则表达式包括(A.D)
      :\1就是重复前面第一个()/组合里面的内容
      :\2就是重复前面第二个()/组合里面的内容
      A. “\b(\w+)\b\s+\1\b”
      B. “\w{2,5}\s*\1”
      C. “(\S+) \s+\1”
      D. “(\S{2,5})\s{1,}\1”

    4. 能够在字符串中匹配“aab”,而不能匹配“aaab”和“aaaab”的正则表达式包括(B. C)
      A. “a*?b”
      B. “a{,2}b”
      C. “aa??b”
      D. “aaa??b”

    相关文章

      网友评论

          本文标题:17作 正则表达式

          本文链接:https://www.haomeiwen.com/subject/ogtpgftx.html