find ./subdirectory -type f 2>>error.log 我从这个命令收到一个错误,比如“find-6ren">
gpt4 book ai didi

unix - 管道查找命令 "stderr"到命令

转载 作者:行者123 更新时间:2023-12-05 01:01:46 26 4
gpt4 key购买 nike

嗨,我有一个奇怪的问题,我正在努力解决 查找 (双关语)它的解决方案。

$> find ./subdirectory -type f 2>>error.log

我从这个命令收到一个错误,比如“find: ./subdirectory/noidea: Permission denied”,这将被重定向到 错误日志 .

在重定向到 之前,有什么方法可以将 stderr 传输到另一个命令错误日志 ?

我希望能够做类似的事情
$> find ./subdirectory -type f 2 | sed "s#\(.*\)#${PWD}\1#" >> error.log

我只想用管道输送 标准错误 sed 命令并获取 find 命令错误的整个路径。

我知道管道在这里不起作用,可能不是正确的方法。

我的问题是我需要 stdout 和 stderr 并且两者都必须同时通过不同的事情进行处理。

编辑:
好的。对我的问题稍作修改。

现在,我有一个 shell 脚本, solve_problem.sh

在这个shell脚本中,我有以下代码
ErrorFile="error.log"
for directories in `find ./subdirectory -type f 2>> $ErrorFile`
do
field1=`echo $directories | cut -d / -f2`
field2=`echo $directories | cut -d / -f3`
done

同样的问题,但在 shell 脚本中。 “find: ./subdirectory/noidea: Permission denied”错误应该进入 $错误文件并且标准输出应该分配给变量 $directories。

最佳答案

同时管道 stderr 和 stdout - 想法取自 this post :

(find /boot | sed s'/^/STDOUT:/' ) 3>&1 1>&2 2>&3 | sed 's/^/STDERR:/'

示例输出:
STDOUT:/boot/grub/usb_keyboard.mod
STDERR:find: `/boot/lost+found': Brak dostępu

Bash 重定向如 3>&1 1>&2 2>&3交换标准错误和标准输出。

我会将您的示例脚本修改为如下所示:
#!/bin/bash
ErrorFile="error.log"
(find ./subdirectory -type f 3>&1 1>&2 2>&3 | sed "s#^#${PWD}: #" >> $ErrorFile) 3>&1 1>&2 2>&3 | while read line; do
field1=$(echo "$line" | cut -d / -f2)
...
done

请注意,我交换了 stdout 和 stderr 两次。

小补充评论-看 -printf查找手册页中的选项。它可能对你有用。

关于unix - 管道查找命令 "stderr"到命令,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9515367/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com