有时遇到一个文件夹下有数百给文件,文件中需要替换某个关键字,或注释行……
手动重复修改很容易出错
这里使用grep/sed/python来简单处理,减轻劳动力
grep -rl #define.*0x80 |sort | uniq > sub_file_list
echo "#define METAL_ISA_XL64_EXTENSIONS 0x8000000000000000UL" | sed \'s/\(#define.*\)\(0x80\)\(.*\)/\1 0x90\3/g\'
./substitude_KeyforPerLine.py --demo print
./substitude_KeyforPerLine.py -h
substitude_KeyforPerLine.py
#!/usr/bin/python
# -*- coding: UTF-8 -*-
import argparse
# Create ArgumentParser() object
parser = argparse.ArgumentParser()
# Add argument
# parser.add_argument('--fl', required=True, help='need modified file list')
parser.add_argument('--fl', help='need modified file list')
parser.add_argument('--demo', help='print grep/sed demo')
# parser.add_argument('--total', type=int, help='number of dataset', default=100)
# Print usage
# parser.print_help()
# Parse argument
args = parser.parse_args()
flist = args.fl
def re_demo():
print("\n");
print(r'echo "#define METAL_ISA_XL64_EXTENSIONS 0x8000000000000000UL" | sed \'s/\(#define.*\)\(0x80\)\(.*\)/\1 0x90\3/g\'')
print(r'grep -rl #define.*0x80 |sort | uniq > sub_file_list'+'\n')
def gen_cmd():
read_list_f=open(flist,'r+')
write_cmd_f=open('modify_line.sh','w')
for line in read_list_f.readlines():
print(r"sed -i -e 's/\(#define.*\)\(0x80\)\(.*\)/\1 0x90\3/g' "+line.strip())
write_cmd_f.write(r"sed -i -e 's/\(#define.*\)\(0x80\)\(.*\)/\1 0x90\3/g' "+line.strip()+"\n")
read_list_f.close()
write_cmd_f.close()
if(args.demo == "print"):
re_demo()
if(flist):
gen_cmd()
原文:https://www.cnblogs.com/OneFri/p/11653428.html