我正在尝试使用Microsoft图形API从onedrive下载文件,我在“新建文件夹”文件夹中有一个名为“ Knox EARNSTSALV2020.xlsx”的文件,但出现错误,我可以从文件夹外部下载文件。
错误:
b'{\r\n "error": {\r\n "code": "itemNotFound",\r\n "message": "Item not found",\r\n "innerError": {\r\n "request-id": "8c4f973a-cd22-48eb-bdfd-f5eb8a051389",\r\n "date": "2020-05-09T10:55:40"\r\n }\r\n }\r\n}'
代码参考:Download files from personal OneDrive using Python
import sys, os, time, requests
import pandas as pd
import urllib.parse
OneDrive_FilePath = 'New Folder/Knox EARNSTSALV2020.xlsx'
OneDrive_FileURL = 'https://graph.microsoft.com/v1.0/me/drive/root:/' + OneDrive_FilePath + ':/content'
OneDrive_FileURL = urllib.parse.quote(OneDrive_FileURL, safe=':/')
print(OneDrive_FileURL)
Client_Id = 'XXXX'
Tenant_Id = 'YYYYY'
Refresh_Token_First = 'ZZZZZ'
PostStr = {'grant_type': 'refresh_token', 'client_id': Client_Id, 'refresh_token': Refresh_Token_First}
Token_Response = requests.post('https://login.microsoftonline.com/' + Tenant_Id + '/oauth2/v2.0/token', data=PostStr)
Access_Token = Token_Response.json()['access_token']
New_Refresh_Token = Token_Response.json()['refresh_token']
if Access_Token is None or New_Refresh_Token is None:
print('\n> Failed: Access_Token NOT Retrieved')
sys.exit()
Response = requests.get(OneDrive_FileURL, headers={'Authorization': 'Bearer ' + Access_Token})
if Response.status_code == 200:
print('\n> Response Success')
with open('Excel File.xlsx', 'wb') as File:
File.write(Response.content)
print('\n> File Downloaded')
else:
print('\n> Failed:', Response.status_code)
print(Response.content)
我的路径中也有空格,我不使用urllib.parse.quote
。尝试使用以下命令调用获取请求:https://graph.microsoft.com/v1.0/me/drive/root:/New Folder/Knox EARNSTSALV2020.xlsx:/content