怎么去除python的注释_Python文件去除注释的方法

本文实例讲述了Python文件去除注释的方法。分享给大家供大家参考。具体实现方法如下:

#!/usr/bin/python

# -*- coding: GBK -*-

#writer:xmnathan

#py文件去注释

import re

import os

import ConfigParser

Python='CleanNote'

def ReadIni(path,section,option):#文件路径,章节,关键词

#读取ini

cf=ConfigParser.ConfigParser()

cf.read(path)

value=cf.get(section,option)#如果用getint()则直接读取该数据类型为整数

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

else:

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')#目的文件夹

#如果目的文件夹不存在,创建之

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文件的注释,并生成拷贝与指定目的文件夹

希望本文所述对大家的Python程序设计有所帮助。

Python函数可变参数定义及其参数传递方式实例详解

本文实例讲述了Python函数可变参数定义及其参数传递方式。分享给大家供大家参考。具体分析如下:python中函数不定参数的定义形式如下:1、func(*args)

Python字符和字符值(ASCII或Unicode码值)转换方法

目的将一个字符转化为相应的ASCII或Unicode码,或相反的操作。方法对于ASCII码(0~255范围)printord('A')65printchr(65)A对于Unicode字符,注意仅接收长度为1的Unic

Python中每次处理一个字符的5种方法

目的对字符串的每个字符进行处理,其实每个字符(Char)就是一个长度为1的字符串。方法1.使用内建函数list()A_string='Python'char_list=list(A_string)char_list['P','y',

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用Python去除Java文件中的注释,可以使用正则表达式和字处理方法。 首先,我们可以使用正则表达式来匹配Java注释的模式。Java注释有两种形式:行注释(以双斜线“//”开始)和块注释(以“/*”开始,以“*/”结束)。我们可以使用正则表达式“//.*|/\*.*?\*/”来匹配注释的模式。 接下来,我们需要读取Java文件的内容,并使用正则表达式匹配注释的模式,并将匹配到的注释替换为空字串。可以使用Python的re模块来实现正则表达式操作。 下面是一个简单的Python代码示例,演示了如何去除Java文件中的注释: ```python import re def remove_comments(file_path): # 读取Java文件内容 with open(file_path, 'r') as file: content = file.read() # 使用正则表达式匹配注释模式并替换为空字串 content = re.sub(r'//.*|/\*.*?\*/', '', content, flags=re.S) # 将处理后的内容写回Java文件 with open(file_path, 'w') as file: file.write(content) # 调用示例 java_file_path = 'example.java' remove_comments(java_file_path) ``` 以上代码中,我们定义了一个`remove_comments`函数,接受Java文件的路径作为参数。函数内部使用`open`函数读取文件内容,并使用`re.sub`函数替换匹配的注释模式为空字串。最后,将处理后的内容写回Java文件。 注意:这只是一个简单的实现示例,不能处理所有可能的情况。对于复杂的注释模式或特殊情况,可能需要进一步优化或修改正则表达式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值