溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python腳本過濾文件中注釋的方法

發(fā)布時間:2020-07-21 11:25:43 來源:億速云 閱讀:241 作者:小豬 欄目:開發(fā)技術

這篇文章主要講解了Python腳本過濾文件中注釋的方法,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。

確保對模塊, 函數(shù), 方法和行內注釋使用正確的風格,Python中的注釋有單行注釋和多行注釋。如果希望去除文件中所有注釋,如何做呢?

Python中的注釋:

Python中單行注釋以 # 開頭,例如:

# 這是一個注釋
print("Hello, World!")

多行注釋用三個單引號 ''' 或者三個雙引號 """ 將注釋括起來,例如:

#!/usr/bin/python3 
'''
這是多行注釋,用三個單引號
這是多行注釋,用三個單引號 
這是多行注釋,用三個單引號
'''
print("Hello, World!")

使用Python腳本快速去除文件中的注釋:

#!/usr/bin/python 
# -*- coding: GBK -*- 
#writer:xmnathan 
#py文件去注釋 
import re 
import os 
import ConfigParser 
Python='CleanNote'
def ReadIni(path,section,option):#文件路徑,章節(jié),關鍵詞 
 #讀取ini
 cf=ConfigParser.ConfigParser() 
 cf.read(path) 
 value=cf.get(section,option)#如果用getint()則直接讀取該數(shù)據(jù)類型為整數(shù) 
 return value 
def IsPassLine(strLine): 
 #是否是可以忽略的行 
 #可忽略行的正則表達式列表 
 RegularExpressions=["""/'.*#.*/'""","""/".*#.*/"""", 
   """/'/'/'.*#.*/'/'/'""","""/"/"/".*#.*/"/"/""""]
 for One in RegularExpressions: 
 zz=re.compile(One) 
 if re.search(zz,strLine)==None: 
  continue
 else: 
  return True#有匹配 則忽略 
 return False
def ReadFile(FileName): 
 #讀取并處理文件 
 fobj=open(FileName,'r') 
 AllLines=fobj.readlines() 
 fobj.close() 
 NewStr='' 
 LogStr='/n%20s/n'%(FileName.split('//')[-1])#輸出的日志 
 nline=0
 for eachiline in AllLines: 
 index=eachline.find('#')#獲取帶注釋句‘#'的位置索引 
 if index==-1 or nline<3 or IsPassLine(eachline): 
  if eachiline.strip()!='':#排除純空的行 
  NewStr=NewStr+eachiline 
  if index!=0: 
  NewStr=NewStr+eachiline[:index]+'/n'#截取后面的注釋部分 
  LogStr+="ChangeLine: %s/t%s"%(nline,eachline[index:]) 
 nline+=1
 return NewStr,LogStr 
def MakeCleanFile(SrcPath,DescPath,FileList): 
 fLog=open(DescPath+'//'+'CleanNoteLog.txt','w') 
 for File in FileList: 
 curStr,LogStr=ReadFile(SrcPath+'//'+File) 
 fNew=open(DescPath+'//'+File,'w') 
 fNew=write(curStr) 
 fNew.close() 
 fLog.write(LogStr) 
 fLog.close() 
def Main(): 
 #從ini獲取源文件夾及目標文件夾路徑 
 IniPath=os.getcwd()+'//'+PtName+'.ini'
 SrcPath=ReadIni(IniPath,PyName,'SrcPath')#源文件夾 
 DescPath=ReadIni(IniPath,PyName,'DescPath')#目的文件夾 
 #如果目的文件夾不存在,創(chuàng)建之 
 if not os.path.exists(DescPath): 
 os.makedirs(DescPath) 
 FileList=[] 
 for files in os.walk(SrcPath): 
 for FileName in files[2]: 
  if FileName.split('.')[-1]=='py': 
  FileList.append(FileName) 
 MakeCleanFile(SrcPath,DescPath,FileList) 
if __name__=='__main__': 
 Main() 
 print '>>>End<<<'
 os.system('pause')

ps:配置文件CleanNote.ini的格式

[CleanNote] 
SrcPath=E:/test 
DescPath=E:/test/newfiles

批量去除指定源文件夾中的py文件的注釋,并生成拷貝與指定目的文件夾

實例擴展:

print("程序中常見的注釋")
 
注意:此程序將會刪除的,會在Demo注釋末尾添加 YES,不會刪除的 NO
 
# 這是第一種注釋,'#'放在開頭(YES)
 
ret = analysix(data)  # 這是第二種注釋,'#'跟在某一個語句后面(NO)
 
"""
第三種注釋
有時候需要注釋掉某一整塊東西的時候,使用這個
(YES)
"""
 
""" 第四種注釋,這是函數(shù)或者類的說明(NO)"""
 
    # 這是第四種注釋,'#'前面加了空格(YES)

看完上述內容,是不是對Python腳本過濾文件中注釋的方法有進一步的了解,如果還想學習更多內容,歡迎關注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

AI