问题现象
最近在做一个java调用远端接口运行python代码的工具,并且通过接口实时获取代码运行的日志,然后使用System.out.printf进行控制台打印,结果出现如下错误:

最关键的是这个问题是偶现的,通过google定位到问题还是因为printf引起的。
Java从1.5版本开始才具体格式化输出的功能,才有了printf这个方法,可以通过指定不同的格式来控制输出样式,其中%表示格式说明的起始符号,不可缺少。而我的问题就是因为接口响应的日志中包含了%,导致printf打印时出现异常。
解决办法
使用 "%%" 去替换掉字符串中的 "%",例如:
String str = "hello world! % w";
System.out.printf(str.replaceAll("%", "%%"));
结果如下:
hello world! % w
总结
只要出现了这个错误,不管Conversion = ‘任意字符’ 中是哪个值,那肯定是你使用了printf打印内容,但是其中包括了%这个关键字符,可以使用多加一个百分号来进行转义(%%)就可以正常输出了。
本文探讨了在Java调用远程Python接口并实时获取日志时遇到的问题,特别是当日志包含百分号(%)时,使用System.out.printf会导致异常。文章详细介绍了如何通过在字符串中将单个百分号替换为双百分号(%%)来解决此问题。

被折叠的 条评论
为什么被折叠?



