我在这里为datetime苦苦挣扎,让脚本只在指定时间内打印事件。我(现在)正在工作,但是需要让脚本遵守硬编码的时间,并且效果不佳
from __future__ import print_function
import datetime
import pickle
import os.path
from googleapiclient.discovery import build
from google_auth_oauthlib.flow import InstalledAppFlow
from google.auth.transport.requests import Request
# If modifying these scopes, delete the file token.pickle.
SCOPES = ['https://www.googleapis.com/auth/calendar.readonly']
def main():
"""Shows basic usage of the Google Calendar API.
Prints the start and name of the next 10 events on the user's calendar.
"""
creds = None
# The file token.pickle stores the user's access and refresh tokens, and is
# created automatically when the authorization flow completes for the first
# time.
if os.path.exists('token.pickle'):
with open('token.pickle', 'rb') as token:
creds = pickle.load(token)
# If there are no (valid) credentials available, let the user log in.
if not creds or not creds.valid:
if creds and creds.expired and creds.refresh_token:
creds.refresh(Request())
else:
flow = InstalledAppFlow.from_client_secrets_file(
'credentials.json', SCOPES)
creds = flow.run_local_server(port=0)
# Save the credentials for the next run
with open('token.pickle', 'wb') as token:
pickle.dump(creds, token)
service = build('calendar', 'v3', credentials=creds)
# Call the Calendar API
now = datetime.datetime.utcnow().isoformat() + 'Z' # 'Z' indicates UTC time
events_result = service.events().list(calendarId='primary', timeMin=now, singleEvents=True, orderBy='startTime').execute()
events = events_result.get('items', [])
if not events:
print('No upcoming events found.')
for event in events:
start = event['start'].get('dateTime', event['start'].get('date'))
print(start, event['summary'])
if __name__ == '__main__':
main()
答案 0 :(得分:0)
这是一种适合您需求的解决方案。
我们声明两个日期。 start_date
,这是我们间隔的开始。 end_date
,这是我们间隔的结束。
end_date
相对于start_date
,可以查看如何在python中的日期时间对象中添加月份/天/小时/等。对于收到的列表中的每个事件,我们将解析给出的日期字符串并将其存储在datetime_obj
2020-10-20
或2020-04-25T20:00:00-04:00
的格式。对于第二个,我不确定结束-04:00
是什么,因为这既不是示例事件的持续时间,也不是结束时间。因此,我将其截断并解析了字符串2020-04-25T20:00:00
现在,我们简单地检查在步骤2中计算的事件日期时间datetime_obj
是否在步骤1 start_time
和end_time
中定义的两个日期之间。如果是这样,我们将打印事件。
start_time = datetime.datetime(2020, 4, 20, 12, 0, 0)
end_time = datetime.datetime(2020, 4, 29, 12, 0, 0)
if not events:
print('No upcoming events found.')
for event in events:
start = event['start'].get('dateTime', event['start'].get('date'))
if (len(start) > 19):
datetime_obj = datetime.datetime.strptime(start[:-6], '%Y-%m-%dT%H:%M:%S')
else:
datetime_obj = datetime.datetime.strptime(start, '%Y-%m-%d')
if (start_time < datetime_obj < end_time):
print(datetime_obj.strftime("%Y-%m-%dT%H:%M:%S"))
print(start, event['summary'])
参考: