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}