Ошибка "Парсер должен быть строкой или символьным потоком, а не datetime" в лямбда-функции aws - не могу понять, как это исправить

Я получаю очень неприятную ошибку при попытке сохранить / протестировать эту функцию Lambda Boto3. Здесь есть другие темы по этой проблеме, но я потратил около 2 часов, пытаясь отладить это, и не могу понять, что я делаю не так (вероятно, это что-то очевидное). Любая помощь будет оценена по достоинству!

{
  "errorMessage": "Parser must be a string or character stream, not datetime",
  "errorType": "TypeError",
  "stackTrace": [
    "  File \"/var/task/lambda_function.py\", line 35, in lambda_handler\n    a = dateutil.parser.parse(instance.launch_time)\n",
    "  File \"/var/runtime/dateutil/parser/_parser.py\", line 1358, in parse\n    return DEFAULTPARSER.parse(timestr, **kwargs)\n",
    "  File \"/var/runtime/dateutil/parser/_parser.py\", line 646, in parse\n    res, skipped_tokens = self._parse(timestr, **kwargs)\n",
    "  File \"/var/runtime/dateutil/parser/_parser.py\", line 722, in _parse\n    l = _timelex.split(timestr)         # Splits the timestr into tokens\n",
    "  File \"/var/runtime/dateutil/parser/_parser.py\", line 207, in split\n    return list(cls(s))\n",
    "  File \"/var/runtime/dateutil/parser/_parser.py\", line 76, in __init__\n    '{itype}'.format(itype=instream.__class__.__name__))\n"
  ]
}
import json
import boto3
import time
import datetime 
import dateutil
from dateutil.parser import parse


def lambda_handler(event, context):
    detailDict = event["detail"]
    ec2 = boto3.resource('ec2')
    instanceId = str(detailDict["instance-id"])
    instance = ec2.Instance(instanceId)
    instanceState = instance.state

    a = dateutil.parser.parse(instance.launch_time)
    b = current_time = datetime.datetime.now(launch_time.tzinfo)

    # returns a timedelta object 
    c = a-b  
    print('Difference: ', c) 

    minutes = c.seconds / 60
    print('Difference in minutes: ', minutes)

    Message=str(instanceId)+" is "+str(instanceState["Name"])
    return {
        'statusCode': 200,
        'body': Message
    }

1 ответ

Решение

В launch-timeсвойство уже является свойством datetime. Разбирать его не нужно.

Ссылка:https://boto3.amazonaws.com/v1/documentation/api/latest/reference/services/ec2.html

Другие вопросы по тегам