我正在处理一个来自商业供应商的文件,该文件在每一行的末尾使用字母Q作为占位符。我需要删除每一行末尾的所有Q,例外的是它永远不应该删除一行中的所有内容。如果一行都是Q,那么它应该只留下一个Q。
我使用这段sed代码删除所有尾随的q...
line=$( echo $line | sed 's/Q*$//' )
...but它不能处理行都是Q的情况,它应该留下1Q。当然,我可以用下面的代码把Q加回去…
if [ -z "$line" ]; then
line="Q"
fi
...but我想学习如何完全在sed中处理这种情况,以备将来参考。示例输出:
TESTQQQQQQ --> TEST
QQQ --> Q
发布于 2018-07-26 03:33:07
使用sed
sed 's/\(.\)Q*$/\1/'
粗略地说,这使用通过\(
和\)
保存的\1
,用零个或多个Q替换任何单个字符.
到行尾的单个字符。它之所以有效,是因为sed
是“贪婪的”。
发布于 2018-07-26 03:24:52
使用awk
,您可以尝试:
awk '/^Q+$/{print "Q"; next} {gsub(/Q+$/,"")} 1' prueba.txt
我假设你只有一个单词来表示行,如果不是这样,请让我知道。
https://stackoverflow.com/questions/51526170
复制相似问题