虽然判断正则对应是否正确的脚本或者网站有很多,自己还是写了一个小脚本,就当练手了。没想到在写的过程中在循环方面还遇到了问题,不知道是应该用while
还是直接使用if
,这都想了半天,太没用了,最后还是完成了脚本的制作。
import re
text = input("输入需要判断的字符串:\n>>> ")
def judge_re():
text_re = input("输入正则表达式:\n>>> ")
if re.match(text_re, text):
print ("原字符串为:\t", text)
print ("\n正则表达式为:\t", text_re)
print ("\n正则表达式正确!")
else:
print ("错误,请重新输入!\n")
judge_re()
judge_re()
效果还是不错的:
===============================================================
更新:
今天早上在看正则的时候看到了脚本中match()
函数。书中提示match()
函数必须从字符串的第0个索引位置处开始搜索,如果第0个索引位置的字符串匹配不成功,match()
函数的匹配失败。说明我上边那个脚本还是有一定局限性的。
这里推荐给大家一个检测正则是否正确的网址:
在实际写脚本中,在给保存到本地的文件命名时我用到了正则替换,函数为:
import re
re.sub(pattern, repl, string, count=0)
这个函数的作用是,根据指定的正则表达式,替换源字符串的字串。pattern
是一个正则表达式,repl
是用于替换的字符串,string
是源字符串。如果count=0
,则返回string
中匹配的所有结果;如果count>0
,则返回count
个匹配结果。
在之前我写的脚本中遇到了命名的问题,那个例子是:
import re
text = "/media/photos/746264"
file_name = re.sub(r"\D+", "0", text) #在使用正则表达式的时候记得加r" "
print (file_name)
这样就实现了替换和文件的命名,避免了文件在命名过程中不能使用特殊字符的问题。