打印多行引发的异常

Dro*_*ans 5 python exception

我正在通过 Python 从 SVN 获取更新。

我有这个:

try: 
    output = subprocess.check_output(svn.update_cmd,
                                     stderr=subprocess.STDOUT, shell=True)
    print output
    print 'finished svn update'

    revision_number = output.split()[-1].rstrip('.') #revision number
    if log_update:
        write_update(revision_number)
    return revision_number
except subprocess.CalledProcessError, e:
    raise SVNUpdateError(e.output)
Run Code Online (Sandbox Code Playgroud)

当我提出自定义时SNVUpdateError,我将换行符打印为\ns。

如果我try:exceptSVNUpdateError,我可以漂亮地打印该行,但它会作为标准输出出现,并传递到下一个代码块。我想提出例外,完全退出任务,并从 SVN 客户端打印结果,以了解为什么在没有换行符和其他特殊字符的情况下事情会向南发展。

谢谢。

Pyr*_*rce 2

由于您使用的是 Python 2.x:

# Usually a simpler error message without newlines
print >>sys.stderr, e.message
# If your message is overly complex, with newlines -- pick a line to print and process it
#print >>sys.stderr, e.message.split('\n')[-1].strip()
# Kill the process
sys.exit(1)
Run Code Online (Sandbox Code Playgroud)

这会将消息(在注释的打印语句中包含受限制的换行符)打印到 stderr 并终止进程。

编辑

如果字符串具有实际的“\\n”字符而不是字符串中的特殊字符“\n”(这意味着某人很可能在字符串创建中的某个位置具有类型),您可以在打印之前进行简单的字符串替换:

print >>sys.stderr, malformatedStr.replace("\\n", "\n")
Run Code Online (Sandbox Code Playgroud)