使用python实现正则匹配检索远端FTP目录下的文件
遇到一个问题,需要正则匹配远端FTP目录下的文件,如果使用ftp客户端可以通过命令行很容易的做到这一点,但是暂时没有一个工具支持这样的需求,于是通过python对FTP的支持和对正则表达式的支持,写了这么一个简单的工具,用于使用正则表达式来匹配远端目录的文件。
代码如下
#coding=utf-8
#########################################################################
#FileName:reg_url.py
#Author:WangWeilong
#Company:Baidu
#########################################################################
importre
importsys
importos
fromftplibimportFTP
dhccmd="http://xxx/api/submit"
classDHC_FTP():
def__init__(self,hostname,username="",passwd=""):
self.hostname=hostname
try:
self.ftp=FTP(self.hostname)
except:
print"hostnameerror!"
exit(-1)
self.username=username
self.passwd=passwd
self.filelist=[]
self.reg_pattern=""
defgetftpfilelist(self,path):
self.ftp.login(self.username,self.passwd)
self.ftp.cwd(path)
self.filelist=self.ftp.nlst()
defmatchnames(self,regpattern):
pattern=re.compile(regpattern)
matchedfiles=[]
forfileinself.filelist:
match=pattern.search(file)
ifmatch:
matchedfiles.append(match.string)
returnmatchedfiles
if__name__=="__main__":
iflen(sys.argv)!=4:
print'usage:pythonreg_url.py$ftpurldir$regular'
else:
#解析ftpurl字符串
head=sys.argv[1].split("@")[1].split("/")[0]
username=sys.argv[1].split("//")[1].split(":")[0]
passwd=sys.argv[1].split("//")[1].split(":")[1].split("@")[0]
pathdir=sys.argv[1].split(head)[1]
dhc_ftp=DHC_FTP(head,username,passwd)
dhc_ftp.getftpfilelist("./"+pathdir)
#获取正则表达式
regpattern=r'%s'%sys.argv[2]
matchedfiles=dhc_ftp.matchnames(regpattern)
forfilesinmatchedfiles:
ftpname=sys.argv[1]+"/"+files
printftpname
通过输入想要的检索的远端目录地址和想要用来匹配的正则表达式,就能获取到远端的文件了,至于用这些文件来干嘛,那就是需求问题了。
以上所述就是本文的全部内容了,希望大家能够喜欢。
请您花一点时间将文章分享给您的朋友或者留下评论。我们将会由衷感谢您的支持!