微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

linux – 如何在unix中删除文件的最后一个字符?

我有一些任意的多行文本文件

sometext
moretext
lastline

如何在不使文本文件无效的情况下仅删除文件的最后一个字符(e,而不是换行符或null)?

解决方法:

一种更简单的方法(输出到stdout,不更新输入文件):

sed '$s/.$//' somefile

> $是仅与最后一行输入行匹配的Sed地址,因此导致以下函数调用(s /.$//)仅在最后一行执行.
> s /.$//用空字符串替换(在本例中为last)行的最后一个字符;即,有效地删除最后一个字符. (换行前)上线.
.匹配该行上的任何字符,并使用$anchors将其匹配到该行的末尾;注意这个正则表达式中$的使用在概念上是如何相关的,但在技术上与以前使用$作为Sed地址有所区别.
> stdin输入示例(假设Bash,Ksh或Zsh):

$sed '$s/.$//' <<< $'line one\nline two'
line one
line tw

要更新输入文件(如果输入文件是符号链接,请不要使用):

sed -i '$s/.$//' somefile

注意:
*在OSX上,您必须使用-i”而不仅仅是-i;有关与-i相关的陷阱的概述,请参见my answer here的下半部分.
*如果您需要处理非常大的输入文件和/或性能/磁盘使用是一个问题,并且您正在使用GNU实用程序(Linux),请参阅sorontar’s helpful answer.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐