当前位置:  开发笔记 > 编程语言 > 正文

在bash中将文本附加到stderr重定向

如何解决《在bash中将文本附加到stderr重定向》经验,为你挑选了1个好方法。

现在我正在使用exec将stderr重定向到错误日志

exec 2>> ${errorLog}

唯一的缺点是我必须以时间戳开始每次运行,因为exec只是将文本直接推送到日志文件中.有没有办法重定向stderr但允许我附加文本,如时间戳?



1> Johannes Sch..:

这很有趣.我问过一个非常了解bash的人,他告诉我这样:

 foo() { while IFS='' read -r line; do echo "$(date) $line" >> file.txt; done; };

首先,它创建了一个从stdin读取一行原始输入的函数,而对IFS的赋值使它不会忽略空白.读完一行后,它会以前面的相应数据输出.然后你必须告诉bash将stderr重定向到该函数:

exec 2> >(foo)

你写入stderr的所有内容现在都将通过foo函数.请注意,当您在交互式shell中执行此操作时,您将不会再看到提示,因为它已打印到stderr,并且foo中的读取是行缓冲的:)

推荐阅读
农大军乐团_697
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有