新闻中心
使用Python在指定Google Drive文件夹中创建Google表单的教程

Google Forms API本身不提供在特定Google Drive文件夹中创建表单的功能。本教程将指导您如何结合使用Google Drive API和Google Forms API,首先利用Drive API在目标文件夹中创建表单的占位符文件,然后使用Forms API填充表单内容,从而实现在指定位置创建Google表单。
引言
在使用Python通过Google Forms API创建Google表单时,一个常见的限制是无法直接指定表单的存储位置。默认情况下,所有新创建的表单都会被放置在您的Google Drive根目录中。这对于需要将表单组织到特定项目或分类文件夹中的用户来说,带来了额外的手动管理负担。Google Forms API的文档中并未提供类似parents这样的参数来在创建时指定父文件夹。
解决方案核心:整合Google Drive API
要解决这一问题,我们需要理解Google表单在Google生态系统中的本质:它被视为Google Drive中的一种特殊文件类型(MIME类型为application/vnd.google-apps.form)。因此,我们可以利用Google Drive API的强大功能来管理这些“文件”的位置。
核心思路是:
立即学习“Python免费学习笔记(深入)”;
- 利用Google Drive API在目标文件夹中创建一个指定MIME类型的空白表单文件。这样,表单的“壳”就直接创建在了我们想要的文件夹中,并获得了其唯一的表单ID。
- 利用Google Forms API,通过上一步获取到的表单ID,对这个空白表单进行内容填充和属性更新(例如设置标题、添加问题等)。
通过这种两步走的策略,我们既能利用Drive API的文件夹管理能力,又能利用Forms API的表单内容编辑能力。
前置准备:API客户端和服务认证
在开始编写代码之前,请确保您已完成以下准备工作:
-
安装必要的库:
Codeium
一个免费的AI代码自动完成和搜索工具
345
查看详情
pip install google-api-python-client google-auth-oauthlib google-auth-httplib2
启用Google API: 在Google Cloud Console中,为您的项目启用“Google Drive API”和“Google Forms API”。
-
设置认证凭据: 下载您的OAuth 2.0客户端凭据文件(通常命名为credentials.json),并将其放置在您的Python脚本同一目录下。 您需要配置正确的API作用域(Scopes)。对于本教程,以下作用域是推荐的:
- https://www.googleapis.com/auth/drive.file:允许访问和管理应用程序创建或打开的文件。
- https://www.googleapis.com/auth/forms.body:允许查看、编辑、创建和删除Google表单的内容。
- https://www.googleapis.com/auth/forms.responses.readonly:如果您还需要读取表单响应,则需要此作用域。
以下是认证代码的通用模板:
import os from google.auth.transport.requests import Request from google.oauth2.credentials import Credentials from google_auth_oauthlib.flow import InstalledAppFlow from googleapiclient.discovery import build # 定义API作用域 SCOPES = [ "https://www.googleapis.com/auth/drive.file", "https://www.googleapis.com/auth/forms.body" ] creds = None # token.json 存储了用户上一次授权的凭据,如果存在,则直接加载 if os.path.exists("token.json"): creds = Credentials.from_authorized_user_file("token.json", SCOPES) # 如果没有有效的凭据,则让用户登录 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)
# 将凭据保存到 token.json,以便下次使用
with open("token.json", "w") as token:
token.write(creds.to_json())
# 构建Drive和Forms服务客户端
drive_service = build("drive", "v3", credentials=creds)
form_service = build("forms", "v1", credentials=creds)
操作步骤详解
接下来,我们将详细介绍如何实现上述两步策略。
1. 获取目标文件夹ID
首先,您需要知道目标Google Drive文件夹的ID。您可以通过以下方式获取:
- 打开Google Drive,导航到您希望创建表单的文件夹。
- 查看浏览器地址栏中的URL,文件夹ID通常是folders/后面的一串字符。 例如:https://drive.google.com/drive/folders/YOUR_FOLDER_ID_HERE
# 替换为您的目标文件夹ID target_folder_id = "YOUR_TARGET_FOLDER_ID"
2. 通过Drive API在指定文件夹中创建空白Google表单
使用drive_service.files().create()方法来创建文件。关键在于设置正确的mimeType为application/vnd.google-apps.form,并指定parents参数为目标文件夹ID。
# 文件元数据,指定名称、MIME类型和父文件夹
file_metadata = {
"name": "我的新项目表单", # 这是在Drive中显示的文件名
"mimeType": "application/vnd.google-apps.form",
"parents": [target_folder_id]
}
try:
# 创建文件,并请求返回文件ID
created_file = drive_service.files().create(
body=file_metadata,
fields="id"
).execute()
form_id = created_file.get("id")
print(f"空白表单已在指定文件夹中创建,ID: {form_id}")
except Exception as e:
print(f"创建表单文件时发生错误: {e}")
form_id = None # 确保在出错时form_id为None执行此步骤后,一个名为“我的新项目表单”的空白Google表单将出现在您指定的Google Drive文件夹中。form_id变量将包含此新表单的唯一标识符。
3. 通过Forms API填充和更新表单内容
现在我们有了form_id,可以使用form_service.forms().batchUpdate()方法来修改表单的标题、描述以及添加问题等。
if form_id:
# 构建更新请求体
# 这里我们更新表单的标题和文档标题,并添加一个文本问题
update_requests = {
"requests": [
{
"updateFormInfo": {
"info": {
"title": "项目反馈表单", # 这是表单在Forms界面中显示的标题
"documentTitle": "项目反馈表单 - 2025 Q4" # 这是Drive中显示的文件名,与name一致更佳
},
"updateMask": "title,documentTitle"
}
},
{
"createItem": {
"item": {
"title": "您的姓名?",
"questionItem": {
"question": {
"textQuestion": {
"paragraph": False
}
}
}
},
"location": {
"index": 0 # 在表单开头添加
}
}
},
{
"createItem": {
"item": {
"title": "您对本次项目的总体评价是?",
"questionItem": {
"question": {
"choiceQuestion": {
"type": "RADIO",
"options": [
{"value": "非常满意"},
{"value": "满意"},
{"value": "一般"},
{"value": "不满意"}
]
}
}
}
},
"location": {
"index": 1 # 在第一个问题之后添加
}
}
}
]
}
try:
# 执行批量更新操作
form_service.forms().batchUpdate(
formId=form_id,
body=update_requests
).execute()
print(f"表单 '{form_id}' 内容已成功更新。")
except Exception as e:
print(f"更新表单内容时发生错误: {e}")
else:
print("无法更新表单,因为表单ID无效。")完整代码示例
将上述认证、创建和更新步骤整合到一个脚本中:
import os
from google.auth.transport.requests import Request
from google.oauth2.credentials import Credentials
from google_auth_oauthlib.flow import InstalledAppFlow
from googleapiclient.discovery import build
# --- 1. 认证和API服务构建 ---
SCOPES = [
"https://www.googleapis.com/auth/drive.file",
"https://www.googleapis.com/auth/forms.body"
]
creds = None
if os.path.exists("token.json"):
creds = Credentials.from_authorized_user_file("token.json", SCOPES)
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)
with open("token.json", "w") as token:
token.write(creds.to_json())
drive_service = build("drive", "v3", credentials=creds)
form_service = build("forms", "v1", credentials=creds)
# --- 2. 定义目标文件夹ID ---
# 替换为您的目标文件夹ID
target_folder_id = "YOUR_TARGET_FOLDER_ID"
if target_folder_id == "YOUR_TARGET_FOLDER_ID":
print("错误:请将 'YOUR_TARGET_FOLDER_ID' 替换为实际的Google Drive文件夹ID。")
exit()
form_id = None
try:
# --- 3. 通过Drive API在指定文件夹中创建空白Google表单 ---
file_metadata = {
"name": "我的新项目表单",
"mimeType": "application/vnd.google-apps.form",
"parents": [target_folder_id]
}
created_file = drive_service.files().create(
body=file_metadata,
fields="id"
).execute()
form_id = created_file.get("id")
print(f"空白表单已在指定文件夹中创建,ID: {form_id}")
# --- 4. 通过Forms API填充和更新表单内容 ---
if form_id:以上就是使用Python在指定Google Drive文件夹中创建Google表单的教程的详细内容,更多请关注其它相关文章!
# 已在
# 营销退推广工具
# 楚雄抖音seo优化加盟
# seo优化朋友圈
# 开县外贸营销推广哪家好
# 温州营销推广多少费用
# 灵武网站优化
# 天津现代网站建设价格
# 中山标题seo优化
# 网站建设提案框架图
# 大连seo快排快速入门
# 多线程
# 方法来
# 您需要
# 自带
# python
# 客户端
# 这是
# 夹中
# 您的
# 表单
# red
# python脚本
# 作用域
# google
# app
# 浏览器
# go
# json
# js
相关栏目:
【
科技资讯46185 】
【
网络学院92790 】
相关推荐:
AngularJS $http POST请求数据传递与Go后端接收实践
企业名称高精度匹配:N-gram方法在结构相似性分析中的应用
不会效仿卡普空!《铁拳》制作人澄清:不采取赛事付费|直播|
漫画星球免费下拉式入口 漫画星球免费漫画在线阅读网站
Mac怎么查看崩溃日志_Mac控制台错误报告分析
漫蛙manwa2最新登录网址_漫蛙manwa2手机网页版入口
PPT平滑切换怎么做 PPT炫酷“平滑”切换动画制作教程【必学】
漫蛙网页登录入口 漫蛙漫画官方授权网址
React/Next.js中实现列表项的动态移动与状态管理:兼论唯一键的重要性
如何在复杂的电商平台中优雅地管理共享资源并确保正确重定向,使用spryker-shop/resource-share-page模块助你一臂之力
Python多版本共存与虚拟环境管理深度指南
聚水潭ERP登录页面入口 聚水潭ERP官网登录界面
Promise错误处理:在catch后终止链式then执行的策略
提升屏幕阅读器对“m”时间单位的播报准确性:HTML与CSS组合解决方案
CSS实现侧边栏导航项全宽圆角悬停背景效果
J*aScript生成器_j*ascript异步迭代
J*aScript实现单选按钮与关联输入框的联动禁用教程
Windows电脑怎么截图最方便_系统自带截图工具的5种神仙用法【技巧】
HuggingFaceEmbeddings中向量嵌入维度调整的限制与理解
蛙漫移动版在线看 蛙漫手机浏览器直达入口
Safari浏览器输入栏卡顿如何解决 Safari搜索建议与缓存清理
批改网学生版PC登录 批改网官网登录系统入口
J*aScript中向JSON对象添加新属性的正确姿势
将HTML动态表格多行数据保存到Google Sheet的教程
PDF文件体积过大处理_PDF压缩技巧详解
163邮箱登录密码 163邮箱忘记密码找回
Composer如何在生产环境安全地执行composer update
邮政快递包裹最新位置 邮政快递实时追踪入口
c++如何实现单例设计模式_c++线程安全的单例模式写法
React项目中导航栏Logo自适应布局:避免裁剪与布局溢出
汽水音乐车机版8.9下载 汽水音乐车机版8.9版本安装入口
Go调试环境为何无法启动_Go调试器启动失败原因与解决策略
WordPress插件开发:正确注册卸载钩子与避免常见陷阱
c++如何使用chrono库处理时间_c++标准库时间与日期操作
J*aScript中正确使用querySelectorAll与复杂CSS选择器
win11 Snap Layouts怎么用 Win11窗口布局与分屏多任务高效指南【必学】
PDF怎么合并PDF并保持格式_PDF合并文件保持排版教程
葱吃多了会怎样 葱吃多了会伤胃吗
J*a 递归快速排序中静态变量的状态管理与陷阱
ACG动漫视频网入口 ACG动漫*免费正版观看地址
处理嵌套交互式控件:前端可访问性指南
Win10双系统截图高效法 截屏快捷键速记【技巧】
steam官方网页快速访问 steam账号注册全流程
QQ邮箱登录官网首页 腾讯QQ邮箱网页入口
vivo手机参数配置怎么增强信号_vivo手机参数配置信号增强方法
Win11如何开启讲述人功能 Win11屏幕阅读器(讲述人)开启与关闭【教程】
虚幻5科幻题材ARPG大作遭取消!本是《奇异人生》厂商新作
《燕云十六声》两周内达九百万玩家!位居畅销榜第五
钉钉视频会议画面卡顿如何解决 钉钉会议画面优化方法
高德地图公交到站提醒失败如何解决 高德提醒权限设置


2025-12-12
浏览次数:次
返回列表
creds = flow.run_local_server(port=0)
# 将凭据保存到 token.json,以便下次使用
with open("token.json", "w") as token:
token.write(creds.to_json())
# 构建Drive和Forms服务客户端
drive_service = build("drive", "v3", credentials=creds)
form_service = build("forms", "v1", credentials=creds)