用递增的文本替换文件中的文本
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 而不是 运行 另一个 sed
或 awk
命令覆盖当前文件。
我在目录中有一个包含此文本的文件
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 而不是 运行 另一个 sed
或 awk
命令覆盖当前文件。