python 批量修改包名

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python 批量修改包名相关的知识,希望对你有一定的参考价值。

#coding=utf-8
import os
#import re

# 设置编码为utf-8 否则会报错。。这时候 sublime控制台会报乱码。但是别担心,utf-8 文件 并不会报错
import sys
reload(sys)
sys.setdefaultencoding( "utf-8" )

#基础包名
basePackage=com.emark.base.注解
#基于基础包名的基本路径名,这里必须是unicode 打开。。。。我也不知道为何别的字符串不用这样写。。。。,其他却不用--
#或者
# basedir = unicode("****",‘utf-8‘)
# decode 将编码转为utf-8  encode utf-8 转为其他编码
# 或者 basedir = u"***" 也是utf-8 编码
basedir=u"E:/emark/emark-manager/src/main/java/com/emark/base/注解"

print basedir

for dirPath,dirNames,fileNames in os.walk(basedir):
    for fileName in fileNames:
        start=len(basedir)
        end=len(dirPath)
        #将\ 替换成 .
        despackage=dirPath[start:].replace("\\",".")
        despackage=basePackage+despackage
        print despackage
        file = os.path.join(dirPath,fileName)
        lines=[]
        with open(file,r+) as files:
            lines=files.readlines() # 返回列表list
        with open(file,"w+") as files:
            for line in lines:
                print line
                if line.startswith("package"):
                    line=package +despackage+"\n"
                files.write(line)

 

decode的作用是将其他编码的字符串转换成unicode编码,如str1.decode(‘gb2312‘),表示将gb2312编码的字符串str1转换成unicode编码。 

encode的作用是将unicode编码转换成其他编码的字符串,如str2.encode(‘gb2312‘),表示将unicode编码的字符串str2转换成gb2312编码。 

以上是关于python 批量修改包名的主要内容,如果未能解决你的问题,请参考以下文章

Python 中使用 ddt 来进行数据驱动,批量执行用例,修改ddt代码

Python批量修改文件名

Python批量修改寄存器的值

python批量修改文件名称

如何用python批量改文件名

python怎样批量修改文件名