这是我想要做的:
我有一个空格分隔的文件,我有一个整数数组。我需要为数组中的每个元素搜索文件 (inv.txt) 的每一行。如果找到模式,我需要保留该行的前 7 个字符并将其余字符替换为“0; 0;”
我对脚本很陌生,到目前为止我尝试过的是:(我想我有点偏离了轨道)
removing=(3199 26543)
for line in inv.txt
do
for i in "${#removing[@]}"
do
sed -i "s/${removing[$1]/c\ ${line:0,7} 0; 0;/g inv.txt
done
done
这给了我一个 sed -e expression #1 char 0: no previous regular expression
我怀疑这是完成任务的最佳方式(如果它甚至会)......感谢任何帮助,提前致谢!
编辑:我正在使用一个数组,因为它实际上将包含几千个条目!我在这个场景中放入的两个只是为了测试。
最佳答案
你实际上可以用一个 sed 做到这一点(如果它支持 -r):
sed -rie '/3199|26543/s/^(.{7}).*/\1\t0;\t0;/' inv.txt
使用数组:
#!/bin/bash
removing=(3199 26543)
( IFS='|'; sed -rie "/${removing[*]}/s/^(.{7}).*/\\1\\t0;\\t0;/" inv.txt; )
关于bash - 替换文件中与 Bash 中的字符串匹配的部分行,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/18281233/