1.写一个正则表达式判断一个字符串是否是ipv4地址。规则:一个ip地址由4个数字组成,每个数字之间用.连接。 每个数字的大小是0-255 例如:255.189.10.37 正确,256.189.89.9 错误。
import re
re_str =r'(([0-1]?\d?\d?|2[0-4]\d|25[0-5])\.){3}([0-1]?\d?\d?|2[0-4]\d|25[0-5])'
result = re.fullmatch(re_str,'255.183.10.37')
print(result)
import re
re_str =r'(([0-1]?\d?\d?|2[0-4]\d|25[0-5])\.){3}([0-1]?\d?\d?|2[0-4]\d|25[0-5])'
result = re.fullmatch(re_str,'256.189.89.9')
print(result)
2.使用正则表达式查找文本中最长的数字字符串。
import re
def longest1(s):
t = re.findall('\d+',s)
print(max(t,key = len))
if t:
return max(t,key = len)
return -1
def longest2(s):
t = re.split("[^\d+]",s)
if t:
return max(t,key = len)
return -1
m = "123xsfhx456789ss123dd4567890fghd34542"
print(longest1(m))
print(longest2(m))
3将一句英语文本中的单词进行倒置,标点不倒置,假设单词之间使用一个或多个空格进行分割。比如I like beijing. 经过函数后变为:beijing. like I。
# 将一句英语文本中的单词进行倒置,标点不倒置,
# 假设单词之间使用一个或多个空格进行分割。
# 比如I like beijing. 经过函数后变为:beijing. like I。
import re
def reverse(s):
t = re.split("\s+",s.strip())
t.reverse()
return ' '.join(t)
print(reverse('I like beijing.'))
4. 编写程序,使用正则表达式提取另一个Python程序中的所有函数名。
import re
fileName = input('请输入一个 Python 程序文件名:')
pattern = r'def (\w+)'
funcNames = []
with open(fileName, encoding='utf8') as fp:
for line in fp:
result = re.findall(pattern, line)
if result:
funcNames.extend(result)
print(funcNames)
截图结果:
说明:这里的文件输入的是本次中的第二题的文件路径自己去找到复制就好了,从第二题的代码中我们可以清楚的看到一共运用了两个函数一个’longest1’,一个 ‘longest2’(鼠标往上扒拉一下)
5.假设有一句英文,其中某个单词中有个不在两端的字母误写作大写,编写程序使用正则表达式进行检查和纠正为小写。注意不要影响每个单词两端的字母
# 假设有一句英文,其中某个单词中有个不在两端的字母误写作大写,
# 编写程序使用正则表达式进行检查和纠正为小写。
# 注意不要影响每个单词两端的字母。
import re
def checkModify(s):
return re.sub(r'\b(\w)(\w+)(\w)\b',lambda x:x.group(1)+x.group(2).lower()+x.group(3),s)
print(checkModify('kdghsoianDKSJZVNSKkdsnvaKkdsfa'))