python的注釋方式和C語言、C++、java有所不同

python語言中,使用‘#' 來進(jìn)行注釋,其次還有使用 三個引號來進(jìn)行注釋
本文的程序?qū)?python 中 使用‘#' 號 好 三個引號的注釋分離出來, 當(dāng)然也能再次合并回去
有需求的小伙伴可以來圍觀了
#!/usr/bin/python
#coding=utf-8
import os
import sys
reload(sys)
sys.setdefaultencoding('utf-8')
class Comment_Filter:
#初始化參數(shù)
def __init__(self):
self.file=None
self.commentfile=None
self.noncommentline=None
self.resotrefile=None
self.Commentline=[]
self.NonCommentline=[]
self.globalcomment=0
#判斷是不是注釋行
def is_Comment_Line(self,line,i):
if i > 2 and line.startswith("#"):
return 1
if line.startswith("'''") and self.globalcomment==1:
self.globalcomment=0
return 1
if line.startswith("'''") and self.globalcomment==0:
self.globalcomment=1
return 1
return self.globalcomment
#保存注釋行
def save_Comment_Line(self,line,i):
self.Commentline.append({"line":line, "line_num":i})
#保存代碼行
def save_NonComment_Line(self,line,i):
self.NonCommentline.append({"line":line, "line_num":i})
#恢復(fù)分離的文件
def restore_Org_File(self):
filename="output/"+self.filename+"_org.txt"
self.resotrefile=open(filename, "w+")
for i in range(1,len(self.Commentline)+len(self.NonCommentline)+1):
for commentline in self.Commentline:
if int(commentline['line_num'])==i:
self.resotrefile.write(commentline['line'])
for noncommentline in self.NonCommentline:
if int(noncommentline['line_num'])==i:
self.resotrefile.write(noncommentline['line'])
print "已輸出到%s" % filename
self.resotrefile.close()
#主運行函數(shù)
def run(self):
if not os.path.exists("output"):
os.mkdir("output")
print "請輸入要處理的文件名"
input_file_name=raw_input()
while len(input_file_name)>1:
print "處理文件為%s" % input_file_name
self.file=open(input_file_name)
self.filename=input_file_name.split(".")[1]
commentfilename="output/"+input_file_name.split(".")[1]+"_comment.txt"
self.commentfile=open(commentfilename,"w+")
noncommentlinename="output/"+input_file_name.split(".")[1]+"_code.txt"
self.noncommentline=open(noncommentlinename,"w+")
i = 0
while self.file != None:
line = self.file.readline()
i +=1
if not line:
print "文件已讀完"
print "以下是注釋內(nèi)容"
for commentline in self.Commentline:
print "第%d行: %s" % (commentline['line_num'],commentline['line'])
self.commentfile.write(commentline['line'])
print "以下是代碼內(nèi)容"
for noncommentline in self.NonCommentline:
print "第%d行: %s" % (noncommentline['line_num'],noncommentline['line'])
self.noncommentline.write(noncommentline['line'])
restore=raw_input("是否恢復(fù)成原文件:")
if restore == 'Y':
self.restore_Org_File()
self.commentfile.close()
self.noncommentline.close()
break
if self.is_Comment_Line(line,i):
self.save_Comment_Line(line,i)
else:
self.save_NonComment_Line(line,i)
print "請輸入文件名"
input_file_name=raw_input('if quit,please input Q:')
if input_file_name == 'Q':
break
if __name__ == '__main__':
print '''
*****************************************
** Welcome to Spider of baidutieba **
** Created on 2017-05-03 **
** @author: Jimy _Fengqi **
*****************************************
'''
my_file_divide_filter=Comment_Filter()
my_file_divide_filter.run()
新聞標(biāo)題:將python代碼和注釋分離的方法-創(chuàng)新互聯(lián)
當(dāng)前鏈接:http://chinadenli.net/article2/egcoc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供全網(wǎng)營銷推廣、云服務(wù)器、定制網(wǎng)站、服務(wù)器托管、網(wǎng)站建設(shè)、品牌網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容