Python Проблемы с аутентификацией O365 по расписанию - PullRequest
0 голосов
/ 31 января 2020

У меня есть сценарий для веб-очистки и отправки данных по электронной почте через пакет O365. Я зарегистрировал приложение с Azure, завершил процесс аутентификации и , код отлично работает в Jupyter Notebook . Однако проблемы начинаются, когда я пытаюсь запустить скрипт через планировщик задач или в командном файле. Вот код:

content = html_template.format(df.to_html(index=False))
credentials = ('AzureappID', 'azureSecret')
account = Account(credentials)
m = account.new_message()
m.to.add('email@x.com')
m.subject = 'Test'
m.body = content
m.send()

Пакетный файл показывает мне эту ошибку, которая появляется в строке m.send():

  File "C:\ProgramData\Anaconda3\lib\site-packages\O365\message.py", line 694, in send
   response = self.con.post(url, data=data)
  File "C:\ProgramData\Anaconda3\lib\site-packages\O365\connection.py", line 787, in post
   return self.oauth_request(url, 'post', data=data, **kwargs)
  File "C:\ProgramData\Anaconda3\lib\site-packages\O365\connection.py", line 763, in oauth_request
   self.session = self.get_session(load_token=True)
  File "C:\ProgramData\Anaconda3\lib\site-packages\O365\connection.py", line 539, in get_session
   raise RuntimeError('No auth token found. Authentication Flow needed')
  RuntimeError: No auth token found. Authentication Flow needed

Похоже, что токен был загружен, но затем в строке "get_session" говорится, что токен не найден. Как я уже сказал, код хорошо работает в Jupyter - кажется, что планировщик задач / командный файл не может найти токен. Я видел здесь , что токен, возможно, нужно сохранить в каталоге root, но я не уверен, где токен хранится, или какой каталог root будет для хранения .

Есть мысли по поводу этого потока аутентификации? Спасибо

...