今天遇到个问题,要把很多个文本里的0替换成1,文本很短,就1-2行,0也就出现一次,我就没多想用powershell大概这样写- (gc a.txt) -replace '0','1' | out-file -encoding oem b.txt
复制代码 对大多数文件没出错
但是
有几个文件是二进制编码,但用记事本打开能看到一部分正常的字符
这替换出来就错了不少。。。
后来改成- sed 's/0/1/' a.txt > b.txt
复制代码 暂时没有出错
就想问问大家,sed替换是不管字符编码的吗,这样理解是否正确,这种替换方式是否安全,是否需要把二进制的文件先转16进制数的表达方式,然后找到数字替换后再转回二进制?
谢谢啦 |