背景:我在服务器上跑一个统计数据的脚本,然后将异常信息就写入到文件,因为我知道使用print 打印异常信息时都没有任何问题,所以我就毫不犹豫的使用f.write(Excep),将异常信息以这样的一种方式写入到文件,今天早上来看数据时,发现是404界面,我就知道可能是脚本出问题了,包括在函数运行时我也用了异常处理,都把错误信息和发生错误的时间写入到文件中。
在文件中发现了以下错误:
f.write('Exception info:' + excep)
TypeError: cannot concatenate 'str' and 'exceptions.TypeError' objects
看字面意思是类型错误导致的,str和exception不是同一类型,不能写入文件,这时候我才明白,自己写了demo测试了下,异常信息exception确实不是str类型的,使用print type(exception)就能看到了,百度了一些资料,发现有些csdn博主写的有些复杂,什么还要写logger.config配置文件的,我觉得复杂了,我倒是在百度知道的一个答案中找到解决方法,Python中有一个函数repe()可以解决,它的参数是object,返回值是string,所以我们借助它就可以将exception转换成string,再写入到字符串中就ok啦
最后我的代码改写成了:
f.write('\n' + 'Exception info:' + repr(excep))
这样这个问题就解决了