用递增的文本替换文件中的文本

Replace text in file with incremented text

我在目录中有一个包含此文本的文件

VERSION_NUMBER: 1

我需要获取 VERSION_NUMBER 的值并将其转换为数字并生成 n+1 并将其写入变量,例如变量 test.

我如何使用 sed

来做到这一点

假设:

  • 输入文件中只有一行
  • 无需验证 : 后面的值是否为数字
  • 无需使用新值更新文件

输入文件:

$ cat myfile
VERSION_NUMBER: 1

一个sed想法:

$ x=$(sed -En 's/^.*: (.*)$//p' myfile)
$ ((x++))
$ echo "${x}"
2

一个cut想法:

$ x=$(cut -d: -f2 myfile)
$ ((x++))
$ echo "${x}"
2

awk 相同:

$ x=$(awk '{print }' myfile)
$ ((x++))
$ echo "${x}"
2


OP 在评论中询问了如何使用新值更新文件。

由于我们只讨论单行,因此...

$ echo "VERSION_NUMBER: ${x}" > myfile

... 可能 easier/simpler 而不是 运行 另一个 sedawk 命令覆盖当前文件。