python-修改目录下带有特定字符的所有文件内容,文件名字,目录名字

python-修改目录下带有特定字符的所有文件内容,文件名字,目录名字

文章目录

问题

写了一个小工具,会检索给定目录下所有文件以及内容,目录的指定的字符,并替换想要的字符

同时会自动判断文档的格式是utf-8,gbk,或者其他类型,保证不读取出错
比如
check_word=[“111”,“222”,“333”,“4444”,“55”,“66”]

解决

import os,shutil
import re
import time
import datetime
import chardet
allFileNum = 0
myfile=[]
mydir=[]

def get_encode(file_my):
    file_my = open(file_my,mode='rb')  # 以二进制模式读取文件
    data = file_my.read()  # 获取文件内容
    file_my.close()  # 关闭文件
    result = chardet.detect(data)  # 检测文件内容
    return result["encoding"]
def printPath(level, path):
    global allFileNum
    ''''' 打印一个目录下的所有文件夹和文件 '''
    # 所有文件夹,第一个字段是次目录的级别
    dirList = []
    # 所有文件
    fileList = []
    # 返回一个列表,其中包含在目录条目的名称(google翻译)
    files = os.listdir(path)
    # 先添加目录级别
    dirList.append(str(level))
    for f in files:
        if (os.path.isdir(path + '/' + f)):
            # 排除隐藏文件夹。因为隐藏文件夹过多
            if (f[0] == '.'):
                pass
            else:
                # 添加非隐藏文件夹
                dirList.append(f)
                mydir.append(path + '/' + f)
        if (os.path.isfile(path + '/' + f)):
            # 添加文件
            fileList.append(f)
            myfile.append(path + '/' + f)
    # 当一个标志使用,文件夹列表第一个级别不打印
    i_dl = 0
    for dl in dirList:
        if (i_dl == 0):
            i_dl = i_dl + 1
        else:
            # print("得到的文件夹",'-' * (int(dirList[0])), dl)
            # 打印目录下的所有文件夹和文件,目录级别+1
            printPath((int(dirList[0]) + 1), path + '/' + dl)
    for fl in fileList:
        # print("得到的文件路径",'-' * (int(dirList[0])), fl)
        # 随便计算一下有多少个文件
        allFileNum = allFileNum + 1
def update_file(file_my):
    print("开始处理文件",file_my)
    #修改文件内容
    check_word=["111","222","333","4444","55","66"]
    change_word=["Learn_Java","learn01","learn02","learn03","learn04","learn05"]
    delete_word=["class"]
    old_name = file_my.split("/")[-1]
    if old_name.split(".")[1] in delete_word:
        os.remove(file_my)
    else:
        f = open(file_my, 'r')
        alllines = f.readlines()
        f.close()
        type_encode=get_encode(file_my)
        f = open(file_my, 'w+',encoding=type_encode)
        for eachline in alllines:
            for i in range(0,len(check_word)):
                eachline =eachline.replace(check_word[i],change_word[i])
            f.writelines(eachline)
        f.close()
        #修改文件名字
        base_path = file_my[:-len(old_name)]
        temp_old_name=old_name
        for i in range(0, len(check_word)):
            old_name = old_name.replace(check_word[i], change_word[i])
        os.rename(os.path.join(base_path,temp_old_name), os.path.join(base_path,old_name))
def update_folder(folder_my):
    print("开始处理文件夹",folder_my)
    #有一个规律,只有最后一个不同路径才是正确的,可修改的,否则就是之前修改过的,因此应该是逆序倒着修改
    charc_list=[]
    temp_folder=folder_my
    judge_name=folder_my.split("/")[-1]
    base_path=folder_my[:-len(judge_name)]
    temp_name=judge_name
    check_word = ["11","22"]
    change_word = ["Learn_Java","Learn_Java01"]
    for i in range(0, len(check_word)):
        judge_name = judge_name.replace(check_word[i], change_word[i])
    if temp_name!=judge_name:#如果名字变化说明不同了,应该修改
        os.rename(temp_folder,base_path+judge_name)
this_folder = input("需要更新信息的代码路径:").replace("\\",'/')
printPath(1, this_folder)
for i in myfile:
    print(i)
    i.replace("\\","/")
    update_file(i)
mydir=sorted(mydir,key=lambda x: len(x),reverse=True)
for i in mydir:
    print(i)
    update_folder(i)
input("已经处理完成,按任意键结束")
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/100236.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • excel如何去掉换行符号_去掉文本中所有换行符

    excel如何去掉换行符号_去掉文本中所有换行符excel中添加换行符::alt+enter去掉excel中的换行符有三种方法:注:解决过程中翻阅其他博客,看到如下方式:1、看到有的说全选后“取消自动换行”,保存后,再打开,依然存在换行符

    2022年8月4日
    64
  • SVN 配置ip访问[通俗易懂]

    SVN 配置ip访问[通俗易懂]之前为了对visualsvnserver服务器进行IP访问控制配置,参考了http://blog.sina.com.cn/s/blog_6dc4dbed0100zass.html介绍的办法解决了这个问题最近svnserver准备升级到V3.7.1版本,发现之前的办法不好使了,启动就直接报错:invalidcommand’Order’,度娘了一把,原来是Apache版本变化导致的.最新…

    2025年11月5日
    2
  • resnet18[通俗易懂]

    resnet18[通俗易懂]前言在前篇vgg16之后,无法成功训练vgg16,发现是自己电脑可用的显存太低了,遂放弃。在2015ILSVRC&COCO比赛中,何恺明团队提出的Resnet网络斩获第一,这是一个经典的网络。李沐说过,如果要学习一个CNN网络,一定是残差网络Resnet。与VGG相比,Resnet则更加出色,为后续的研究做下铺垫这是Resnet论文翻译参考链接:https://blog.csdn.net/weixin_42858575/article/details/93305238在之前的神经

    2022年5月26日
    69
  • 海量数据存储技术(cpu制造瓶颈)

    对于海量数据的处理随着互联网应用的广泛普及,海量数据的存储和访问成为了系统设计的瓶颈问题。对于一个大型的互联网应用,每天几十亿的PV无疑对数据库造成了相当高的负载。对于系统的稳定性和扩展性造成了极大的问题。通过数据切分来提高网站性能,横向扩展数据层已经成为架构研发人员首选的方式。水平切分数据库:可以降低单台机器的负载,同时最大限度的降低了宕机造成的损失;负载均衡策略:可以降低单台机器的访问负载,降…

    2022年4月14日
    52
  • Entity Framework Extended Library (EF扩展类库,支持批量更新、删除、合并多个查询等)…

    Entity Framework Extended Library (EF扩展类库,支持批量更新、删除、合并多个查询等)…

    2021年8月24日
    48
  • WebConfig中常用的connectionStrings配置[通俗易懂]

    WebConfig中常用的connectionStrings配置[通俗易懂]WEBCONFIG中常用的connectionStrings配置一般配置模板–语法示例<connectionStrings><add name=”connection” connectionString=”DataSource=10.42.44.228;InitialCatalog=leftover_sys;PersistSecurityInfo=True;UserID=root;Password=123456″ providerName=”S

    2022年5月11日
    37

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号