Python 从异常中的对象读取属性
我试图从错误对象读取属性,同时捕获异常。错误来自芹菜工人 下面我展示了芹菜出错的控制台:Python 从异常中的对象读取属性,python,django,celery,Python,Django,Celery,我试图从错误对象读取属性,同时捕获异常。错误来自芹菜工人 下面我展示了芹菜出错的控制台: [2019-12-15 16:38:41,442: ERROR/MainProcess] Task api.tasks.sendSms[139dbbbd-df85-4528-a131-973848fb4f80] raised unexpected: AttributeError("'ERR_UNKNOWN' object has no attribute 'Text'") Traceback (most r
[2019-12-15 16:38:41,442: ERROR/MainProcess] Task api.tasks.sendSms[139dbbbd-df85-4528-a131-973848fb4f80] raised unexpected: AttributeError("'ERR_UNKNOWN' object has no attribute 'Text'")
Traceback (most recent call last):
File "/share/backend/backendsmsgateapi/api/tasks.py", line 16, in sendSms
status = smsServiceObject.sendParcicularSms(receiver, template)
File "/share/backend/backendsmsgateapi/api/smsService.py", line 38, in sendParcicularSms
state_machine.SendSMS(message)
gammu.ERR_UNKNOWN: {'Text': 'Nieznany błąd.', 'Where': 'SendSMS', 'Code': 27}
During handling of the above exception, another exception occurred:
Traceback (most recent call last):
File "/share/backend/myenv/lib/python3.7/site-packages/celery/app/trace.py", line 385, in trace_task
R = retval = fun(*args, **kwargs)
File "/share/backend/myenv/lib/python3.7/site-packages/celery/app/trace.py", line 648, in __protected_call__
return self.run(*args, **kwargs)
File "/share/backend/backendsmsgateapi/api/tasks.py", line 20, in sendSms
message = getattr(error_object, "Text")
AttributeError: 'ERR_UNKNOWN' object has no attribute 'Text'
我的代码部分是:
@shared_task
def sendSms(template, receiver, duration):
try:
smsServiceObject = smsService()
status = smsServiceObject.sendParcicularSms(receiver, template)
time.sleep(duration)
except:
error_object = sys.exc_info()[1]
message = getattr(error_object, "Text")
data = {
"success" : False,
"error_info": message,
"receiver": receiver
}
return data
data = {
"success": True,
"receiver": receiver
}
return data
正如您所看到的,问题在于:
message = getattr(error_obj, "Text")
但是为什么呢?在控制台中,对象ERROR_UKNOWN的属性为“Text”,值为“Neznany błąd”。
为什么它不起作用?我将非常感谢您的帮助。请尝试以下方法:
error_object = sys.exc_info()[1]
message = error_object.args[0]['Text']
data = {
"success" : False,
"error_info": message,
"receiver": receiver
}
return data
将所有相关代码和错误直接作为文本发布到此处。好的,请稍等片刻(我拍了一张照片,因为它在raspberry pi上)。好的,我已从控制台和IDE将照片更改为粘贴代码。您如何知道
error\u obj
对象具有text
属性?因为:gammu.ERR\u未知:控制台打印中的{'Text':'nieznanybłąd.','Where':'SendSMS','Code':27}