编译过程中最烦的就是报错 \65279
这是因为代码中采用了 utf-8有bom的编码格式,如果有大量文件有bom,那一个一个的修改成无bom模式是很恼火的,用python可以实现批量转化有bom为无bom,bom其实就是在文件的开头,插入了3bit的bom头
\xef\xbb\xbf
用python按二进制读取文件,检查开头是否有bom头,如果有就删掉,没有就算了,这样就把有bom的全部替换成无bom的了。
代码如下:
def removeBom(file):
'''移除UTF-8文件的BOM字节'''
BOM = b'\xef\xbb\xbf'
existBom = lambda s: True if s == BOM else False
f = open(file, 'rb')
if existBom(f.read(3)):
fbody = f.read()
# f.close()
with open(file, 'wb') as f:
f.write(fbody)
if __name__ == '__main__':
for root, dirs, files in os.walk("E:\\project\\java\\perbank"):
for file in files:
if file.find(".java") != -1:
removeBom(os.path.join(root, file))
这样就能把目录下的所有java代码中含有bom的删掉