批量去除UTF-8的BOM前缀(python3版)

编译过程中最烦的就是报错 \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的删掉

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值