加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

bash – 有更简洁的方法来获取每一行的最后N个字符吗?

发布时间:2020-12-16 01:14:29 所属栏目:安全 来源:网络整理
导读:为简化讨论,设N = 3. 我目前提取文件或流中每行的最后三个字符的方法是使用sed捕获组中的最后三个字符,并用该组替换整行. sed 's/^.*(.{3})/1/' 它有效但看起来过于冗长,特别是当我们比较一行中获得前三个字符的方法时. cut -c -3 是否有更简洁的方法来
为简化讨论,设N = 3.

我目前提取文件或流中每行的最后三个字符的方法是使用sed捕获组中的最后三个字符,并用该组替换整行.

sed 's/^.*(.{3})/1/'

它有效但看起来过于冗长,特别是当我们比较一行中获得前三个字符的方法时.

cut -c -3

是否有更简洁的方法来提取每行中的最后N个字符?

使用grep -o’… $’非常简单:
cat /etc/passwd  | grep -o '...$'
ash
/sh
/sh
/sh
ync
/sh
/sh
/sh

或者更好的是:

N=3; grep -o ".{$N}$" </etc/passwd
ash
/sh
/sh
/sh
ync
/sh
/sh

这样你就可以根据自己喜欢的价值调整你的N.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读