gpt4 book ai didi

regex - 复杂任务的简单解决方案

转载 作者:行者123 更新时间:2023-11-29 09:10:27 24 4
gpt4 key购买 nike

我很好奇这个看似复杂的任务是否有简单的解决方案:

假设我有这个文件:

lineone
linetwo
linethree
linefour

lineone
linetwo
linethree
linefour

lineone
lineone
lineone
linetwo
linethree
linefour

有没有一种简单的方法可以得到这个结果:

lineone[1]
linetwo[1]
linethree[1]
linefour[1]

lineone[2]
linetwo[2]
linethree[2]
linefour[2]

lineone[3]
lineone[4]
lineone[5]
linetwo[3]
linethree[3]
linefour[3]

换句话说,是否有一个简单的 bash 算法可以让我按照每行在文件中出现的顺序对每一行进行编号?如果没有一些涉及额外存储的复杂解决方案,我无法找到一种方法来执行此操作,并且我用于行替换的常用命令在这里毫无用处。 sed 只会用相同的值替换所有出现的行,而字符串替换 ( ${string/substring/replace} ) 对我没有帮助,因为它不会保持行的顺序。

非常感谢。

最佳答案

下面的 awk 命令通过保存行数组及其计数来工作。

awk '{if($0~/./){a[$0]++;print $0"["a[$0]"]";} else print}' file

例子:

$ cat file
lineone
linetwo
linethree
linefour

lineone
linetwo
linethree
linefour

lineone
linetwo
linethree
linefour

lineone
lineone
lineone
linetwo
linethree
linetwo

$ awk '{if($0~/./){a[$0]++;print $0"["a[$0]"]";} else print}' file
lineone[1]
linetwo[1]
linethree[1]
linefour[1]

lineone[2]
linetwo[2]
linethree[2]
linefour[2]

lineone[3]
linetwo[3]
linethree[3]
linefour[3]

lineone[4]
lineone[5]
lineone[6]
linetwo[4]
linethree[4]
linetwo[5]

关于regex - 复杂任务的简单解决方案,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13976752/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com