python 一些常用的小脚本
作者:明月清风旧
本文主要介绍了python 一些常用的小脚本,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
找到指定后缀的文件列表
找到指定后缀的文件,返回找到的文件路径列表,会递归文件夹。
import os # 找到指定后缀的文件 def find_type(path:str,fix:str): dlist=os.listdir(path) file_list=[] for i in dlist: ps=os.path.join(path, i) if os.path.isdir(ps): file_list+=find_type(ps,fix) else: if(ps[-len(fix):]==fix): file_list.append(ps) return file_list
转换文件编码
示例为把gb2312编码的文件转化为utf8编码。
def conv(file:str): s="" try: with open(file,encoding="gb2312") as f: s=f.read() os.remove(file) with open(file,mode="w+",encoding="utf-8") as f: f.write(s) except Exception as e: print("conv failed",file)
删除文件注释
输入文件名,行注释标签,块注释标签,生成删除注释后的文件保存并覆盖原文件。
例如C语言使用 // 和 /* */ 来注释,调用方式如下:
del_comm("main.c","//",["/*","*/"])
# 删除所有注释 def del_comm(file:str,line_comm:str,blok_comm:list[str]): text="" try: with open(file,encoding="utf-8") as f: lines=f.readlines() except Exception as e: print("decode failed",file) return for i in range(len(lines)): index=lines[i].find(line_comm) if(index>=0): lstr=lines[i][:index] else: lstr=lines[i].rstrip() if(len(lstr.strip())>0): text+=lstr+'\n' elif(text[-2:]=='\\\n'): text+='\n' index_start=0 text_out="" while True: index=text.find(blok_comm[0],index_start) index_end=text.find(blok_comm[1],index) if(index>=0 and index_end>index): text_out+= text[index_start:index] index_start=index_end+len(blok_comm[1]) else: text_out+=text[index_start:] break with open(file,mode="w+",encoding="utf-8") as f: f.write(text_out)
去除过多的空白字符
def simplified(text:str): ''' 返回一个新字符串,去除过多的空白字符 ''' space=['\t', '\n', '\v', '\f', '\r', ' '] r="" start=0 is_empty=False while text[start] in space: start+=1 for i in range(start,len(text)): if text[i] in space: is_empty=True else: if(is_empty==True): r+=" " is_empty=False r+=text[i] return r
到此这篇关于python 一些常用的小脚本的文章就介绍到这了,更多相关python 常用脚本内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!