2018-09-11 day17作业

  1. 写一个正则表达式判断一个字符串是否是ip地址
    规则:一个ip地址由4个数字组成,每个数字之间用.连接。每个数字的大小是0-255
    255.189.10.37 正确
    256.189.89.9 错误
# 0-9  :\d
# 10-99  :[1-9]\d
# 100-199  :1[0-9]{2}
# 200-249  :2[0-4][0-9]
# 250-255   :25[0-5]
in_put = input('IP:')
re_str = r'(\d|[1-9]\d|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.\d|[1-9]\d|1[0-9]{2}|2[0-4][0-9]|25[0-5]'
result = fullmatch(re_str,in_put)
if result:
    print('ip地址正确')
else:
    print('ip地址不正确')
  1. 计算一个字符串中所有的数字的和
    例如:字符串是:‘hello90abc 78sjh12.5’ 结果是90+78+12.5 = 180.5
str1='hello90abc 78sjh12.5'
re_str=r'\d+[.]\d+|\d+'
search1=search(re_str,str1)
sum=float(search1.group())
while True:
    str1=str1[search1.end():]
    search1=search(re_str,str1)
    if not search1:
        break
    sum+=float(search1.group())
print(sum)
  1. 验证输入的内容只能是汉字
str1 = input('请输入汉字:')
re_str = r'[一-禧]+'
result = fullmatch(re_str, str1)
print(result)
if result:
    print('全是汉字')
else:
    print('不全是汉字')
  1. 电话号码的验证
in_put = input('电话号码:')
re_str = r'1[34578]\d{9}'
result = fullmatch(re_str,in_put)
if result:
    print('电话号码正确')
else:
    print('电话号码不正确')
  1. 简单的身份证号的验证
# 前6位  :\d{6}
# 年 :1900--2018
# 1900-1999  :19\d\d
# 2000-2009  :200\d
# 2010-2018  :201\d
# 月 01-12
# 01-09  :0[1-9]
# 10-12  :1[0-2]
# 日  01--31
# 01-09   :0[1-9]
# 10-29   :[12]\d
# 30-31   :3[01]
# 三位数字   :\d{3}
# 数字/x: [\dx]

re_str = r'\d{6}(19\d\d|200\d|201\d)(0[1-9]|1[0-2])(0[1-9]|[12]\d|3[01])\d{3}[\dx]'
sesult = fullmatch(re_str,in_put)
if result:
    print('身份证号码正确')
else:
    print('身份证号码不正确')

二、不定项选择题

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

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

  1. 能够完全匹配字符串“c:\rapidminer\lib\plugs”的正则表达式包括( BC )
    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”的正则表达式包括( ABCD )
    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”的正则表达式包括(AD )
    :\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”的正则表达式包括( BC )
    A. “a*?b”
    B. “a{,2}b”
    C. “aa??b”
    D. “aaa??b”

你可能感兴趣的:(2018-09-11 day17作业)