Как удалить микросекунды из DateTime - PullRequest
1 голос
/ 16 июня 2020

Привет, я использую библиотеку win32com.client для чтения электронных писем из общего почтового ящика Outlook, и я получаю сообщение об ошибке: микросекунда должна быть в 0..999999. Я попытался отформатировать "ReceivedDate" как "% Y-% D-% M% H:% M:% S", но безуспешно. ты знаешь, что еще я могу попробовать?

import win32com.client

def readEmail():
outlook = win32com.client.Dispatch("Outlook.Application").GetNamespace("MAPI")
folder = outlook.Folders.Item('SharedMailbox, TEST')
inbox = folder.Folders.Item('Inbox')
messages = inbox.Items

counter = 0
for message in messages:
    rcvd_dt = message.ReceivedTime
    if message.FlagRequest != 'Follow up' and str(rcvd_dt) >= '2020-06-01 00:00:00':
    counter  +=1
    print(counter)
    print(received_dt)

трассировка:

Traceback (most recent call last):
File "C:/Users/TEST/PycharmProjects/TEST/Metrics.py", line 422, in <module>
main()
File "C:/Users/TEST/PycharmProjects/TEST/Metrics.py", line 409, in main
readEmail()
File "C:/Users/TEST/PycharmProjects/TEST/Metrics.py", line 89, in readEmail
rcvd_dt = message.ReceivedTime
File "C:\Program Files (x86)\Python37-32\lib\site- 
packages\win32com\client\dynamic.py", line 516, in __getattr__
ret = self._oleobj_.Invoke(retEntry.dispid,0,invoke_type,1)
ValueError: microsecond must be in 0..999999

Что я пробовал:

rcvd_dt= datetime.strptime(str(rcvd_dt.split('.')[0], '%Y-%m-%d %H:%M:%S')

, но получаю ошибку:

valueerror: time data '2' does not match format %Y-%m-%d %H:%M:%S.%f'

, если я попробую:

rcvd_dt= datetime.strptime(str(rcvd_dt.split('.')[0], '%Y-%m-%d %H:%M:%S.%f')

получаю:

valueerror: time data '2020-06-16 08:53:56' does not match format %Y-%m-%d.%f' 

Ответы [ 2 ]

2 голосов
/ 16 июня 2020

«У вас должно быть 50 репутации, чтобы оставлять комментарии»

rcvd_dt= datetime.strptime(str(rcvd_dt.split('.')[0], '%Y-%m-%d %H:%M:%S')

С этим вы на правильном пути. Ошибка, с которой вы столкнулись, возникла из rcvd_dt.split('.')[0]. Не может быть "." в строке, чтобы отделить строку даты и времени, и заставил ее прочитать '2' из первого индекса.

0 голосов
/ 16 июня 2020

Я считаю, что вы также можете извлечь год, месяц ... вот так:

rcvd_dt.year, rcvd_dt.month, rcvd_dt.day, ...
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...