我有一个脚本可以进行网络抓取,并通过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中运行良好-似乎任务计划程序/批处理文件找不到令牌。我已经见过here,可能需要将令牌保存在根目录中,但是我不确定令牌的存储位置或适合存储的根目录。
对此身份验证流程有任何想法吗?谢谢
答案 0 :(得分:1)
我有同样的问题。根据文档,用户应使用FileSystemTokenBackend。我最终创建了一个名为“ o365_token.txt”的文件,并将其存储在与脚本相同的文件夹中。我相信这是使用FileSystemTokenBackend创建令牌后文件的默认名称。 O365 Documentation FileSystemTokenBackend