调用 MS Graph API 以收集在线 MS 表单回复
Call MS Graph API to collect Online MS Form responses
是否有通过 MS Graph API 从共享的在线 MS 表单收集回复的解决方案?
我将 MS Graph API 用于其他目的,即访问 OneDrive 中的 personal/shared 文件。
我找不到直接的解决方案来访问在线表格。 Microsoft 提出了一些请求,他们回应说该选项在积压工作中。我想知道是否有替代解决方案可以通过 API 访问共享的在线 MS 表单?
不幸的是,没有 图表 api 可以做同样的事情。
我可以想到两种选择:
选项 1:
您可以使用 LogicAPP 或使用 Power Automate(以前称为 MS Flow)维护您自己的表单响应数据源
只要为表单记录了新响应以及已在响应中填写的数据,就会调用此触发器。
有了它,您可以将此响应导出到存储在 OneDrive、Sharepoint、Azure 存储等中的 CSV 文件中(附加到现有响应)。这样您就可以在需要时通过图形 API 使用此 CSV。
或将回复作为列表项添加到 Sharepoint 在线列表。您可以通过 Graph API.
获取列表项
https://docs.microsoft.com/en-us/graph/api/resources/listitem?view=graph-rest-1.0
选项 2:
注意:如果您在非 Web 应用程序中执行操作,则此方法可能适用。
因为您正试图通过 Python 实现您的目标。我认为您可以将 Selenium 用于 WebBrowser。
获取 Answer 响应的 API 如下:
GET https://forms.office.com/formapi/api/<tenantid>/users/<userid>/light/forms('<formid>')/responses?$expand=comments&$top=7&$skip=0
上述请求的响应示例:
这里的问题是,目前无法获取上述 API 的访问令牌。 (据我研究)
因此,我所做的解决方法是利用 Selenium。
例如 - 使用 ChromeDriver 和 Selenium 库自动执行以下过程:
您可以参考这篇文章 https://www.browserstack.com/guide/python-selenium-to-run-web-automation-test 了解我们如何使用 python-chrome.
进行浏览器自动化
第 1 步:
自动登录 https://forms.office.com。
此步骤将为会话创建必要的 cookie 以访问表单 api
第 2 步:
现在在同一会话中点击 api
GET https://forms.office.com/formapi/api/<tenantid>/users/<userid>/light/forms('<formid>')/responses?$expand=comments&$top=7&$skip=0
您将得到输出作为响应:
可以对其进行评估并随后用于处理。
是否有通过 MS Graph API 从共享的在线 MS 表单收集回复的解决方案?
我将 MS Graph API 用于其他目的,即访问 OneDrive 中的 personal/shared 文件。
我找不到直接的解决方案来访问在线表格。 Microsoft 提出了一些请求,他们回应说该选项在积压工作中。我想知道是否有替代解决方案可以通过 API 访问共享的在线 MS 表单?
不幸的是,没有 图表 api 可以做同样的事情。
我可以想到两种选择:
选项 1:
您可以使用 LogicAPP 或使用 Power Automate(以前称为 MS Flow)维护您自己的表单响应数据源
只要为表单记录了新响应以及已在响应中填写的数据,就会调用此触发器。
有了它,您可以将此响应导出到存储在 OneDrive、Sharepoint、Azure 存储等中的 CSV 文件中(附加到现有响应)。这样您就可以在需要时通过图形 API 使用此 CSV。
或将回复作为列表项添加到 Sharepoint 在线列表。您可以通过 Graph API.
获取列表项https://docs.microsoft.com/en-us/graph/api/resources/listitem?view=graph-rest-1.0
选项 2:
注意:如果您在非 Web 应用程序中执行操作,则此方法可能适用。
因为您正试图通过 Python 实现您的目标。我认为您可以将 Selenium 用于 WebBrowser。
获取 Answer 响应的 API 如下:
GET https://forms.office.com/formapi/api/<tenantid>/users/<userid>/light/forms('<formid>')/responses?$expand=comments&$top=7&$skip=0
上述请求的响应示例:
这里的问题是,目前无法获取上述 API 的访问令牌。 (据我研究)
因此,我所做的解决方法是利用 Selenium。
例如 - 使用 ChromeDriver 和 Selenium 库自动执行以下过程:
您可以参考这篇文章 https://www.browserstack.com/guide/python-selenium-to-run-web-automation-test 了解我们如何使用 python-chrome.
进行浏览器自动化第 1 步: 自动登录 https://forms.office.com。 此步骤将为会话创建必要的 cookie 以访问表单 api
第 2 步: 现在在同一会话中点击 api
GET https://forms.office.com/formapi/api/<tenantid>/users/<userid>/light/forms('<formid>')/responses?$expand=comments&$top=7&$skip=0
您将得到输出作为响应:
可以对其进行评估并随后用于处理。