当前位置: 首页 > news >正文

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程序设计有所帮助。

相关文章:

  • qtdesigner 如何清空输入框_如何进行开发需求分解?
  • struts2 404找不到action_看到这些404页面文案,就算网页打不开也值了
  • filezilla 后文件传输失败_超好用!这款大文件传输工具,能把其他软件摁在地上摩擦!...
  • python淘宝秒杀脚本视频教程_Python脚本实现淘宝准点秒杀功能
  • 大数据学习路线_好程序员大数据学习路线分享UDF函数
  • pythonscatter简书_Python笔记 - tkinter
  • 模糊查询正则语句_数据分析进阶—简单查询
  • python编写一个排序函数要求数据输入_python自学日记9——选择数据结构
  • python输出语句print_Python每日3题print(c)会输出什么?
  • 命令行参数python sys模块_Python中处理命令行参数的3种方法
  • python菜鸟教程for循环_Python for 循环语句
  • 格力手机2 官方固件_格力悄悄上线首部双模5G手机:搭载骁龙765G,售价2699元起...
  • c#怎么拟合函数得到参数_数值计算(三十七)给定函数的参数拟合
  • python decorators_Python进阶之强大的装饰器 Decorators (一)
  • 设备能力指数cmk计算公式_拧紧微课堂|关于CM,CMK,CP,CPK
  • [ JavaScript ] 数据结构与算法 —— 链表
  • 【Leetcode】104. 二叉树的最大深度
  • ES6系列(二)变量的解构赋值
  • go语言学习初探(一)
  • Intervention/image 图片处理扩展包的安装和使用
  • iOS 颜色设置看我就够了
  • JS正则表达式精简教程(JavaScript RegExp 对象)
  • Nodejs和JavaWeb协助开发
  • Spring核心 Bean的高级装配
  • Traffic-Sign Detection and Classification in the Wild 论文笔记
  • 持续集成与持续部署宝典Part 2:创建持续集成流水线
  • 翻译--Thinking in React
  • 基于遗传算法的优化问题求解
  • 入门级的git使用指北
  • 使用 Xcode 的 Target 区分开发和生产环境
  • 腾讯视频格式如何转换成mp4 将下载的qlv文件转换成mp4的方法
  • 原生Ajax
  • 大数据全解:定义、价值及挑战
  • 京东物流联手山西图灵打造智能供应链,让阅读更有趣 ...
  • ​决定德拉瓦州地区版图的关键历史事件
  • ​软考-高级-系统架构设计师教程(清华第2版)【第1章-绪论-思维导图】​
  • ###51单片机学习(2)-----如何通过C语言运用延时函数设计LED流水灯
  • (1)Map集合 (2)异常机制 (3)File类 (4)I/O流
  • (20)目标检测算法之YOLOv5计算预选框、详解anchor计算
  • (3)nginx 配置(nginx.conf)
  • (附源码)spring boot球鞋文化交流论坛 毕业设计 141436
  • (转)Android中使用ormlite实现持久化(一)--HelloOrmLite
  • (转)可以带来幸福的一本书
  • (转)一些感悟
  • ../depcomp: line 571: exec: g++: not found
  • ./和../以及/和~之间的区别
  • .NET 4.0网络开发入门之旅-- 我在“网” 中央(下)
  • .net framework4与其client profile版本的区别
  • .net反编译的九款神器
  • .NET中GET与SET的用法
  • .NET中使用Protobuffer 实现序列化和反序列化
  • @Autowired和@Resource装配
  • @reference注解_Dubbo配置参考手册之dubbo:reference
  • [ MSF使用实例 ] 利用永恒之蓝(MS17-010)漏洞导致windows靶机蓝屏并获取靶机权限
  • []error LNK2001: unresolved external symbol _m