替换txt文件中每行的匹配文本的第一个实例

时间:2018-04-04 06:58:33

标签: bash macos sed grep text-processing

我有一个.txt文件,我希望在每一行替换匹配字符串的第一个匹配项。

所以,例如,这里是foo.txt里面的内容:

838dbc65cd79e16cf09f90abb928e3f3d0ea2d775cf8edc8acaabde6d393bc76  /Volumes/Documents - Part 1/legos.png
415ccf1e05fb5985d2f719deabec7bb5d22aeaac7b82cca885010b12d483d997  /Volumes/Documents - Part 1/folder/Volumes/Documents - Part 1/another folder/Volumes/Documents - Part 1 BU/fedora linux.7z
f3d0ea2d775cf8edc1ddbd76e2562d3e4a2e281fe2aeb1333ef99536d1a180ee  /Volumes/Documents - Part 1/manuals/dryer.pdf
\ba7816bf8f01cfea414140de5dae2223b00361a396177a9cb410ff61f20015ad  /Volumes/Documents - Part 1/Test Hash Folder/#;."'&,\\{2}:`!*?$(){}[]<>|-=+% [meowzers] (1)~^^.$[E-frLOL[MAY[]{}()?<NUL>
\9c993445f7f6216b4fc7d35aef47afa16f4f831f2510b7fddd1e42c4cafb518c  /Volumes/Documents - Part 1/Test Hash Folder/#;."'&,\\:`!CAT      MEOW!!![hey]{15}(hello)@$%&^*(#@@*?$(){}[]<>|-=+% ~^^.$[E-frLOL[MAY[]{}()?<NUL>

我想将Documents - Part 1替换为Documents - Part 1 BU仅替换每一行的第一次出现。

所以,它最终看起来像这样:

838dbc65cd79e16cf09f90abb928e3f3d0ea2d775cf8edc8acaabde6d393bc76  /Volumes/Documents - Part 1 BU/legos.png
415ccf1e05fb5985d2f719deabec7bb5d22aeaac7b82cca885010b12d483d997  /Volumes/Documents - Part 1 BU/folder/Volumes/Documents - Part 1/another folder/Volumes/Documents - Part 1 BU/fedora linux.7z
f3d0ea2d775cf8edc1ddbd76e2562d3e4a2e281fe2aeb1333ef99536d1a180ee  /Volumes/Documents - Part 1 BU/manuals/dryer.pdf
\ba7816bf8f01cfea414140de5dae2223b00361a396177a9cb410ff61f20015ad  /Volumes/Documents - Part 1 BU/Test Hash Folder/#;."'&,\\{2}:`!*?$(){}[]<>|-=+% [meowzers] (1)~^^.$[E-frLOL[MAY[]{}()?<NUL>
\9c993445f7f6216b4fc7d35aef47afa16f4f831f2510b7fddd1e42c4cafb518c  /Volumes/Documents - Part 1 BU/Test Hash Folder/#;."'&,\\:`!CAT      MEOW!!![hey]{15}(hello)@$%&^*(#@@*?$(){}[]<>|-=+% ~^^.$[E-frLOL[MAY[]{}()?<NUL>

我试过了:

cat foo.txt | grep "^.[\]{64}  /Volumes/Documents - Part 1/" | sed "  /Volumes/Documents - Part 1 BU"`

但它不起作用。我该如何解决这个问题?

Mac OS X Yosemite,bash 3.2.57(1)-release,grep(BSD grep)2.5.1-FreeBSD

1 个答案:

答案 0 :(得分:2)

解决方案第一: 关注sed可能对您有帮助。

sed 's/Documents - Part 1/Documents - Part 1 BU/'   Input_file

解决方案第二: awk解决方案。

awk '{sub("Documents - Part 1","Documents - Part 1 BU")} 1'   Input_file

注意: 如果您想将输出保存到Input_file本身并将sed -i附加到第二个解决方案,请使用上面代码中的> temp_file && mv temp_file Input_file选项做同样的事。

相关问题