99999久久久久久亚洲,欧美人与禽猛交狂配,高清日韩av在线影院,一个人在线高清免费观看,啦啦啦在线视频免费观看www

熱線電話:13121318867

登錄
首頁精彩閱讀將python代碼和注釋分離的方法
將python代碼和注釋分離的方法
2018-06-01
收藏

python代碼和注釋分離的方法

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

python語言中,使用‘#' 來進(jìn)行注釋,其次還有使用 三個(gè)引號來進(jìn)行注釋

本文的程序?qū)?python 中 使用‘#' 號 好 三個(gè)引號的注釋分離出來, 當(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()
    #主運(yùn)行函數(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()

本程序已知問題, 不能處理 空格之后在以‘#' 開頭的注釋,所有的注釋行,必須是頂格寫的
以后有時(shí)間的話,再重新寫一版完整的吧
以上這篇將python代碼和注釋分離的方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考

數(shù)據(jù)分析咨詢請掃描二維碼

若不方便掃碼,搜微信號:CDAshujufenxi

數(shù)據(jù)分析師資訊
更多

OK
客服在線
立即咨詢
客服在線
立即咨詢
') } function initGt() { var handler = function (captchaObj) { captchaObj.appendTo('#captcha'); captchaObj.onReady(function () { $("#wait").hide(); }).onSuccess(function(){ $('.getcheckcode').removeClass('dis'); $('.getcheckcode').trigger('click'); }); window.captchaObj = captchaObj; }; $('#captcha').show(); $.ajax({ url: "/login/gtstart?t=" + (new Date()).getTime(), // 加隨機(jī)數(shù)防止緩存 type: "get", dataType: "json", success: function (data) { $('#text').hide(); $('#wait').show(); // 調(diào)用 initGeetest 進(jìn)行初始化 // 參數(shù)1:配置參數(shù) // 參數(shù)2:回調(diào),回調(diào)的第一個(gè)參數(shù)驗(yàn)證碼對象,之后可以使用它調(diào)用相應(yīng)的接口 initGeetest({ // 以下 4 個(gè)配置參數(shù)為必須,不能缺少 gt: data.gt, challenge: data.challenge, offline: !data.success, // 表示用戶后臺檢測極驗(yàn)服務(wù)器是否宕機(jī) new_captcha: data.new_captcha, // 用于宕機(jī)時(shí)表示是新驗(yàn)證碼的宕機(jī) product: "float", // 產(chǎn)品形式,包括:float,popup width: "280px", https: true // 更多配置參數(shù)說明請參見:http://docs.geetest.com/install/client/web-front/ }, handler); } }); } function codeCutdown() { if(_wait == 0){ //倒計(jì)時(shí)完成 $(".getcheckcode").removeClass('dis').html("重新獲取"); }else{ $(".getcheckcode").addClass('dis').html("重新獲取("+_wait+"s)"); _wait--; setTimeout(function () { codeCutdown(); },1000); } } function inputValidate(ele,telInput) { var oInput = ele; var inputVal = oInput.val(); var oType = ele.attr('data-type'); var oEtag = $('#etag').val(); var oErr = oInput.closest('.form_box').next('.err_txt'); var empTxt = '請輸入'+oInput.attr('placeholder')+'!'; var errTxt = '請輸入正確的'+oInput.attr('placeholder')+'!'; var pattern; if(inputVal==""){ if(!telInput){ errFun(oErr,empTxt); } return false; }else { switch (oType){ case 'login_mobile': pattern = /^1[3456789]\d{9}$/; if(inputVal.length==11) { $.ajax({ url: '/login/checkmobile', type: "post", dataType: "json", data: { mobile: inputVal, etag: oEtag, page_ur: window.location.href, page_referer: document.referrer }, success: function (data) { } }); } break; case 'login_yzm': pattern = /^\d{6}$/; break; } if(oType=='login_mobile'){ } if(!!validateFun(pattern,inputVal)){ errFun(oErr,'') if(telInput){ $('.getcheckcode').removeClass('dis'); } }else { if(!telInput) { errFun(oErr, errTxt); }else { $('.getcheckcode').addClass('dis'); } return false; } } return true; } function errFun(obj,msg) { obj.html(msg); if(msg==''){ $('.login_submit').removeClass('dis'); }else { $('.login_submit').addClass('dis'); } } function validateFun(pat,val) { return pat.test(val); }