在 Ruby 中抑制系统调用的顽固控制台输出
Suppressing stubborn console output on system calls in Ruby
我正在从 ruby 中调用 imagemagik 的转换程序来转换图像类型。我将 stdout 和 stderr 重定向到 /dev/null 但我仍然收到控制台文本。它仅在从 webp 转换时发生,所以我怀疑它是 Ubuntu webp 包的输出。
buffer = `convert -quiet "#{temp_dir}#{tmp_image_filename}" "#{temp_dir}#{new_image_filename}" > /dev/null 2>&1`
输出:
Decoded /tmp/magick-3658rrhNn7wh4IW2. Dimensions: 580 x 300 . Format: lossy. Now saving...
Saved file /tmp/magick-3658nGuNL-bzCkRA
这是tty输出吗?我不知道如何捕获和压制它。我添加了 quiet 属性来转换命令行,但它没有任何影响(我怀疑 webp 是罪魁祸首的另一个原因)。我在我的 Whosebug 搜索中尝试了其他几个技巧,包括系统、IO、包装在 : $(...) 等中,但都无济于事。有帮助吗?
谢谢!
埃里克
问题已在评论中得到解答。我使用如下格式移动到 Open3.capture3,并捕获了来自 webp 的控制台文本。
stdout, stderr, status = Open3.capture3("convert -flatten \"#{$temp_dir}#{tmp_image_filename}\" \"#{$temp_dir}#{@image_filename}\"")
我正在从 ruby 中调用 imagemagik 的转换程序来转换图像类型。我将 stdout 和 stderr 重定向到 /dev/null 但我仍然收到控制台文本。它仅在从 webp 转换时发生,所以我怀疑它是 Ubuntu webp 包的输出。
buffer = `convert -quiet "#{temp_dir}#{tmp_image_filename}" "#{temp_dir}#{new_image_filename}" > /dev/null 2>&1`
输出:
Decoded /tmp/magick-3658rrhNn7wh4IW2. Dimensions: 580 x 300 . Format: lossy. Now saving...
Saved file /tmp/magick-3658nGuNL-bzCkRA
这是tty输出吗?我不知道如何捕获和压制它。我添加了 quiet 属性来转换命令行,但它没有任何影响(我怀疑 webp 是罪魁祸首的另一个原因)。我在我的 Whosebug 搜索中尝试了其他几个技巧,包括系统、IO、包装在 : $(...) 等中,但都无济于事。有帮助吗?
谢谢! 埃里克
问题已在评论中得到解答。我使用如下格式移动到 Open3.capture3,并捕获了来自 webp 的控制台文本。
stdout, stderr, status = Open3.capture3("convert -flatten \"#{$temp_dir}#{tmp_image_filename}\" \"#{$temp_dir}#{@image_filename}\"")