摘要:代碼如下解析字符串獲取正則表達(dá)式通過輸入想要的檢索的遠(yuǎn)端目錄地址和想要用來匹配的正則表達(dá)式,就能獲取到遠(yuǎn)端的文件了,至于用這些文件來干嘛,那就是需求問題了。
遇到一個問題,需要正則匹配遠(yuǎn)端FTP目錄下的文件,如果使用ftp客戶端可以通過命令行很容易的做到這一點,但是暫時沒有一個工具支持這樣的需求,于是通過python對FTP的支持和對正則表達(dá)式的支持,寫了這么一個簡單的工具,用于使用正則表達(dá)式來匹配遠(yuǎn)端目錄的文件。
代碼如下
# coding=utf-8 ######################################################################### # File Name: reg_url.py # Author: WangWeilong # Company: Baidu ######################################################################### import re import sys import os from ftplib import FTP dhccmd = "http://xxx/api/submit" class DHC_FTP(): def __init__(self, hostname, username="", passwd=""): self.hostname = hostname try: self.ftp = FTP(self.hostname) except: print "hostname error!" exit(-1) self.username = username self.passwd = passwd self.filelist = [] self.reg_pattern = "" def getftpfilelist(self, path): self.ftp.login(self.username, self.passwd) self.ftp.cwd(path) self.filelist = self.ftp.nlst() def matchnames(self, regpattern): pattern = re.compile(regpattern) matchedfiles = [] for file in self.filelist: match = pattern.search(file) if match: matchedfiles.append(match.string) return matchedfiles if __name__ == "__main__": if len(sys.argv) != 4: print "usage:python reg_url.py $ftpurldir $regular" else: #解析ftpurl字符串 head = sys.argv[1].split("@")[1].split("/")[0] username = sys.argv[1].split("http://")[1].split(":")[0] passwd = sys.argv[1].split("http://")[1].split(":")[1].split("@")[0] pathdir = sys.argv[1].split(head)[1] dhc_ftp = DHC_FTP(head, username, passwd) dhc_ftp.getftpfilelist("./" + pathdir) #獲取正則表達(dá)式 regpattern = r"%s" % sys.argv[2] matchedfiles = dhc_ftp.matchnames(regpattern) for files in matchedfiles: ftpname = sys.argv[1] + "/" + files print ftpname
通過輸入想要的檢索的遠(yuǎn)端目錄地址和想要用來匹配的正則表達(dá)式,就能獲取到遠(yuǎn)端的文件了,至于用這些文件來干嘛,那就是需求問題了。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/37495.html
摘要:前端最基礎(chǔ)的就是。我這邊預(yù)期準(zhǔn)備進(jìn)入中級階段,中間還是會穿插一些實戰(zhàn)。語法精確匹配,匹配成功,則停止搜索正則不能有嵌套的。指令會根據(jù)在配置文件中出現(xiàn)的順序依次執(zhí)行,可以使用來終止接下來的處理。如果以或者或者,則停止處理,立刻重定向。 前端最基礎(chǔ)的就是 HTML+CSS+Javascript。掌握了這三門技術(shù)就算入門,但也僅僅是入門,現(xiàn)在前端開發(fā)的定義已經(jīng)遠(yuǎn)遠(yuǎn)不止這些。前端小課堂(HTM...
閱讀 769·2023-04-25 19:43
閱讀 4022·2021-11-30 14:52
閱讀 3855·2021-11-30 14:52
閱讀 3909·2021-11-29 11:00
閱讀 3838·2021-11-29 11:00
閱讀 3949·2021-11-29 11:00
閱讀 3613·2021-11-29 11:00
閱讀 6310·2021-11-29 11:00