對(duì)Python 檢查文件名是否規(guī)范的實(shí)例詳解
更新時(shí)間:2019年06月10日 12:03:10 作者:愚公丨Acmen
今天小編就為大家分享一篇對(duì)Python 檢查文件名是否規(guī)范的實(shí)例詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧
如下所示:
# coding=utf-8
import os
import os.path
import re
import array
import cmd
import pdb
import pickle
import tempfile
import subprocess
# rootPath = os.getcwd()
# print rootPath
rootPath = raw_input('The Check Path:')
nonCheckDir = raw_input('The Non Check DirName(DirName1;DirName2):')
nonCheckDirList = []
if nonCheckDir:
nonCheckDirList = nonCheckDir.split(';')
# 路徑字典
pathDic = {}
# 新建文件夾 os.path.isdir(rootdir+'/logout') 判斷指定目錄下該文件夾是否存在
if not os.path.isdir(rootPath+'/logout'):
os.makedirs(rootPath + '/logout')
logPath=os.path.join(rootPath,'logout')
nonstandard_filename_path = open(logPath+'/nonstandard_filename_path.txt','w')
# 標(biāo)準(zhǔn)的符號(hào)庫(kù)
num = "0123456789"
word = "abcdefghijklmnopqrstuvwxyz"
sym = "_."
# 符號(hào)庫(kù)
symBank = []
for key in word:
symBank.append(key)
for key in num:
symBank.append(key)
for key in sym:
symBank.append(key)
def GetAllDir(getPath):
# print (getPath)
paths = os.listdir(getPath)
for dirName in paths:
dirPath = os.path.join(getPath,dirName)
if os.path.isdir(dirPath) and dirName != '.svn':
# print dirPath
relPath = dirPath[len(rootPath)+1:len(dirPath)]
# print relPath
if not nonCheckDirList.__contains__(relPath):
pathDic[relPath] = dirPath
GetAllDir(dirPath)
def GetAllFile(getPath):
files = os.listdir(getPath)
for fileName in files:
filePath = os.path.join(getPath,fileName)
if fileName.endswith('.png') or fileName.endswith('.PNG'):
fileName = fileName[0:fileName.index('.')]
if not set(fileName).issubset(symBank):
# print fileName
# print filePath
nonstandard_filename_path.write(filePath + '\n')
else:
# (r'_[\d]*[x|X][\d]*\d') 正則表達(dá)式 (_100x100)
sign = re.search(r'_[\d]*[x|X][\d]*\d',fileName,re.M|re.I)
if sign:
nonstandard_filename_path.write(filePath + '\n')
if __name__ == '__main__':
print ('main')
pathDic['curPath'] = rootPath
GetAllDir(rootPath)
for key in pathDic:
# print key
GetAllFile(pathDic[key])
# line = "image_500100000"
# obj = re.search(r'_[\d]*[x|X][\d]*\d',line,re.M|re.I)
# line = line.replace(obj.group(),'=')
# if obj:
# print obj.group()
# else:
# print ("==-")
# line1 = "image_500x100"
# obj1 = re.search(r'[a-z0-9_]*',line1,re.M)
# print obj1.group()
新建bat后綴文件
find_nonstandard_name.exe -c @pause
修改后腳本
# coding=utf-8
import os
import os.path
import re
import array
import cmd
import pdb
import pickle
import tempfile
import subprocess
import sys
import getopt
rootPath = ""
nonCheckDirList = sys.argv[1:]
opts, args = getopt.getopt(sys.argv[1:],"cs:",["cPath="])
for opt,arg in opts:
if opt == '-c':
rootPath = os.getcwd()
elif opt in ("-s","--cPath"):
rootPath = arg
# 路徑字典
pathDic = {}
# 新建文件夾 os.path.isdir(rootdir+'/logout') 判斷指定目錄下該文件夾是否存在
if not os.path.isdir(rootPath+'/logout'):
os.makedirs(rootPath + '/logout')
logPath=os.path.join(rootPath,'logout')
nonstandard_filename_path = open(logPath+'/nonstandard_filename_path.txt','w')
def GetAllDir(getPath):
# print (getPath)
paths = os.listdir(getPath)
for dirName in paths:
dirPath = os.path.join(getPath,dirName)
if os.path.isdir(dirPath) and dirName != '.svn':
# print dirPath
relPath = dirPath[len(rootPath)+1:len(dirPath)]
# print relPath
if not nonCheckDirList.__contains__(relPath):
pathDic[relPath] = dirPath
GetAllDir(dirPath)
def GetAllFile(getPath):
files = os.listdir(getPath)
for fileName in files:
filePath = os.path.join(getPath,fileName)
if fileName.endswith('.png') or fileName.endswith('.PNG'):
fileName = fileName[0:fileName.index('.')]
firstSign = re.search(r'^[a-z0-9_]*$',line1,re.M)
if firstSign:
# print filePath
# (r'_[\d]*[x|X][\d]*\d') 正則表達(dá)式 (_100x100)
sign = re.search(r'_[\d]*[x|X][\d]*\d', fileName, re.M | re.I)
if sign:
print fileName
nonstandard_filename_path.write(filePath + '\n')
else:
print fileName
nonstandard_filename_path.write(filePath + '\n')
if __name__ == '__main__':
print ('main')
pathDic['curPath'] = rootPath
GetAllDir(rootPath)
for key in pathDic:
# print key
GetAllFile(pathDic[key])
添加檢查文件重名功能
# coding=utf-8
import os
import os.path
import re
import array
import cmd
import pdb
import pickle
import tempfile
import subprocess
import sys
import getopt
nonCheckDirList = sys.argv[1:]
rootPath = os.getcwd()
checkRepetPathList = []
if nonCheckDirList:
rootPath = os.path.realpath(os.path.join(os.getcwd(),nonCheckDirList[0]))
if nonCheckDirList[0] == "./":
rootPath = os.getcwd()
for _path in nonCheckDirList:
# -- 檢查重命名路徑
_cmdRepet = _path[0:2]
if _cmdRepet == "/r":
repetPath = _path[len(_cmdRepet):len(_path)]
print repetPath
checkRepetPathList.append(repetPath)
print rootPath + '\n'
# 路徑字典
pathDic = {}
# 重名路徑字典
repetDic = {}
# 新建文件夾 os.path.isdir(rootdir+'/logout') 判斷指定目錄下該文件夾是否存在
# if not os.path.isdir(rootPath+'/logout'):
# os.makedirs(rootPath + '/logout')
# logPath=os.path.join(rootPath,'logout')
logPath = os.getcwd()
nonstandard_filename_path = open(logPath+"\\"+u"不規(guī)范命名文件".encode("GBK") + ".txt",'w')
def GetAllDir(getPath):
# print (getPath)
paths = os.listdir(getPath)
for dirName in paths:
dirPath = os.path.join(getPath,dirName)
if os.path.isdir(dirPath) and dirName != '.svn':
# print dirPath
relPath = dirPath[len(rootPath)+1:len(dirPath)]
# print relPath
if not nonCheckDirList.__contains__(relPath):
pathDic[relPath] = dirPath
GetAllDir(dirPath)
def GetAllFile(getPath):
files = os.listdir(getPath)
for fileName in files:
filePath = os.path.join(getPath,fileName)
if fileName.endswith('.png') or fileName.endswith('.PNG'):
fileName = fileName[0:fileName.index('.')]
firstSign = re.search(r'^[a-z0-9_]*$',fileName,re.M)
if firstSign:
# print filePath
# (r'_[\d]*[x|X][\d]*\d') 正則表達(dá)式 (_100x100)
sign = re.search(r'_[\d]*[x|X][\d]*\d', fileName, re.M | re.I)
if sign:
print fileName
nonstandard_filename_path.write(filePath + '\n')
else:
print fileName
nonstandard_filename_path.write(filePath + '\n')
def CheckRepetFile(getPath):
if checkRepetPathList:
paths = os.listdir(getPath)
for dirName in paths:
dirPath = os.path.join(getPath, dirName)
if os.path.isdir(dirPath) and dirName != '.svn':
# print dirPath
relPath = dirPath[len(rootPath) + 1:len(dirPath)]
# print relPath
repetDic[relPath] = dirPath
CheckRepetFile(dirPath)
imageList = []
repetImagePath = []
def GetCheckRepetFile(getPath):
files = os.listdir(getPath)
for fileName in files:
filePath = os.path.join(getPath, fileName)
if fileName.endswith('.png') or fileName.endswith('.PNG'):
# print filePath
imageList.append(fileName)
repetImagePath.append(filePath)
repet_filename_path = open(logPath+"\\"+u"重復(fù)命名文件".encode("GBK") + ".txt",'w')
if __name__ == '__main__':
# print ('main')
pathDic['curPath'] = rootPath
GetAllDir(rootPath)
for key in pathDic:
# print key
GetAllFile(pathDic[key])
print '\n' + "The Logout Path:" + logPath+"\\"+u"不規(guī)范命名文件".encode("GBK") + ".txt"
repetDic['curPath'] = rootPath
# 檢查重復(fù)文件路徑列表
for __path in checkRepetPathList:
_repetPath = os.path.join(rootPath, __path)
CheckRepetFile(_repetPath)
# 遍歷路徑獲得所有圖片
for key in repetDic:
GetCheckRepetFile(repetDic[key])
_newImageList = []
for image in imageList:
repetCount = imageList.count(image)
if repetCount > 1 :
if not image in _newImageList:
_newImageList.append(image)
for repetImage in _newImageList:
print repetImage
repet_filename_path.write(repetImage + '\n')
for repetPathPath in repetImagePath:
fileNameName = os.path.basename(repetPathPath)
if repetImage == fileNameName:
repet_filename_path.write(repetPathPath + '\n')
# print repetPathPath
print '\n' + "The Logout Path:" + logPath+"\\"+u"重復(fù)命名文件".encode("GBK") + ".txt"
以上這篇對(duì)Python 檢查文件名是否規(guī)范的實(shí)例詳解就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
上手簡(jiǎn)單,功能強(qiáng)大的Python爬蟲框架——feapder
這篇文章主要介紹了上手簡(jiǎn)單,功能強(qiáng)大的Python爬蟲框架——feapder的使用教程,幫助大家更好的利用python進(jìn)行爬蟲,感興趣的朋友可以了解下2021-04-04
python批量telnet檢測(cè)IP地址的端口是否開放
本文主要介紹了python批量telnet檢測(cè)IP地址的端口是否開放,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04
Python第三方庫(kù)jieba庫(kù)與中文分詞全面詳解
jieba庫(kù)是一款優(yōu)秀的Python第三方中文分詞庫(kù),jieba支持三種分詞模式:精確模式、全模式和搜索引擎模式,下面這篇文章主要給大家介紹了關(guān)于Python第三方庫(kù)jieba庫(kù)與中文分詞的相關(guān)資料,需要的朋友可以參考下2022-07-07
pymysql.err.DataError:1366的報(bào)錯(cuò)解決
通過python把數(shù)據(jù)同步至mysql數(shù)據(jù)庫(kù)的過程中,遇到錯(cuò)誤,本文主要介紹了pymysql.err.DataError:1366的報(bào)錯(cuò)解決,具有一定的參考價(jià)值,感興趣的可以了解一下2024-05-05
解決Tensorflow使用pip安裝后沒有model目錄的問題
今天小編就為大家分享一篇解決Tensorflow使用pip安裝后沒有model目錄的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2018-06-06

