Python如何腳本過濾文件中的注釋
確保對模塊, 函數(shù), 方法和行內(nèi)注釋使用正確的風(fēng)格,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é),關(guān)鍵詞
#讀取ini
cf=ConfigParser.ConfigParser()
cf.read(path)
value=cf.get(section,option)#如果用getint()則直接讀取該數(shù)據(jù)類型為整數(shù)
return value
def IsPassLine(strLine):
#是否是可以忽略的行
#可忽略行的正則表達(dá)式列表
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獲取源文件夾及目標(biāo)文件夾路徑
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("程序中常見的注釋")
注意:此程序?qū)h除的,會在Demo注釋末尾添加 YES,不會刪除的 NO
# 這是第一種注釋,'#'放在開頭(YES)
ret = analysix(data) # 這是第二種注釋,'#'跟在某一個語句后面(NO)
"""
第三種注釋
有時候需要注釋掉某一整塊東西的時候,使用這個
(YES)
"""
""" 第四種注釋,這是函數(shù)或者類的說明(NO)"""
# 這是第四種注釋,'#'前面加了空格(YES)
到此這篇關(guān)于Python如何腳本過濾文件中的注釋的文章就介紹到這了,更多相關(guān)Python腳本過濾文件中的注釋方法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 詳解python中的異常捕獲
- Python try except異常捕獲機制原理解析
- 解決python ThreadPoolExecutor 線程池中的異常捕獲問題
- python中異常捕獲方法詳解
- python使用布隆過濾器的實現(xiàn)示例
- Python filter過濾器原理及實例應(yīng)用
- python怎么對數(shù)字進(jìn)行過濾
- Python過濾掉numpy.array中非nan數(shù)據(jù)實例
- Python中使用filter過濾列表的一個小技巧分享
- python numpy實現(xiàn)多次循環(huán)讀取文件 等間隔過濾數(shù)據(jù)示例
- python爬蟲之異常捕獲及標(biāo)簽過濾詳解
相關(guān)文章
PyTorch中Tensor的數(shù)據(jù)類型和運算的使用
這篇文章主要介紹了PyTorch中Tensor的數(shù)據(jù)類型和運算的使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09
Python中input和raw_input的一點區(qū)別
這篇文章主要介紹了Python中input和raw_input的一點區(qū)別,它們都是用來讀取控制臺輸入的函數(shù),需要的朋友可以參考下2014-10-10
Django基礎(chǔ)知識 URL路由系統(tǒng)詳解
這篇文章主要介紹了Django基礎(chǔ)知識 URL路由系統(tǒng)詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-07-07
python實現(xiàn)將代碼轉(zhuǎn)成不可反編譯的pyd文件
pyc文件用于提高加載速度,部分源碼可讀,而pyd文件提供更好的保密性,是編譯后的二進(jìn)制動態(tài)鏈接庫,當(dāng)有些模塊的代碼需要一定的保密性,這個時候就需要考慮pyc和pyd文件了,本文給大家介紹了python實現(xiàn)將代碼轉(zhuǎn)成不可反編譯的pyd文件,需要的朋友可以參考下2024-11-11

