svn: warning: W160035: Path '/README.txt' is alread-6ren">
gpt4 book ai didi

ruby - bash 脚本的 %x 返回空字符串而不是实际结果

转载 作者:数据小太阳 更新时间:2023-10-29 08:23:06 24 4
gpt4 key购买 nike

value = %x( #{"svn lock #{@path}/#{@file}"} )

=>

svn: warning: W160035: Path '/README.txt' is already locked by user 'tester' in filesystem 'some_path'
""

返回空字符串而不是 svn:warning 消息。我想记录 svn 警告信息。我究竟做错了什么。

提前感谢您的帮助。

最佳答案

这可能是因为输出被发送到 STDERR,而不是 STDOUT(所有 %x 捕获)。因为您没有捕获它,所以它会执行正常操作并打印到控制台。

您可以在命令中将 STDERR 重定向到 STDOUT:

%x(svn lock #{@path}/#{@file} 2>&1)

或者使用Open3捕获 STDOUT 和 STDERR:

require 'open3'

Open3.popen3("svn lock #{@path}/#{@file}") do |stdin, stdout, stderr, wait_thr|
puts "stdout is:" + stdout.read
puts "stderr is:" + stderr.read
end

第一个选项将工作卸载到执行命令的 shell,并且根据环境,它可能不支持它。因此,使用 Open3 是一种更便携的解决方案。

一些附加说明:请注意,我已经删除了您的 %x 语句中不必要的插值。另外,考虑使用 ShellWords在 shell 命令中正确转义内插字符串。如果这些是用户输入的字符串,这一点尤为重要。

关于ruby - bash 脚本的 %x 返回空字符串而不是实际结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21831896/

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