在 Google 教室中列出学生的作业时出现问题
Problem listing assignments of a student in Google Classroom
我开始使用课堂 API 来增强我们学校的本地应用程序。为了为 class 做一份报告,我想列出所有学生的作业和评分。我使用循环遍历学生的所有课程,然后是每门课程的所有课程作业,然后是每门课程作业的所有提交。这是我使用的一段代码:
function fListWorkStudent(idStudent)
{
// Variables
var pageToken = null;
var optionalArgs =
{
pageToken: pageToken,
courseStates: 'ACTIVE',
studentId: idStudent,
pageSize: 0
};
var optionalArgs2 =
{
pageToken: pageToken,
userId: idStudent,
pageSize: 0
};
// Courses for a student
var response = Classroom.Courses.list(optionalArgs);
var sCourses = response.courses;
if (sCourses.length === 0)
Logger.log("No courses");
else
{
for (course in sCourses)
{
var idCourse=sCourses[course].id;
var nomprof=getUserName(sCourses[course].ownerId);
// Coursework for every course
var responseW = Classroom.Courses.CourseWork.list(idCourse);
var works = responseW.courseWork;
if (works && (works.length > 0))
{
for work in works)
{
var idWork=works[work].id;
// Submissions for every coursework
var responseS = Classroom.Courses.CourseWork.StudentSubmissions.list(idCourse, idWork, optionalArgs2);
var submissions = responseS.studentSubmissions;
if (submissions && submissions.length >0)
{
for (submission in submissions)
{
// Prepare report here
}
}
}
}
}
}
}
此代码的问题在于,当我调用 Classroom.Courses.CourseWork.StudentSubmissions.list(idCourse, idWork, optionalArgs2) 以过滤所选学生的提交时,循环到达未分配给该学生的课程作业,调用失败并出现错误 'classroom.courses.courseWork.studentSubmissions.list; error: Requested entity was not found.'
如果在调用 API 函数之前课程作业未分配给该学生,我可以通过检查循环来解决它,或者可能使用 try..catch 子句来捕获可能的错误,但我想知道是否这个问题有一个更聪明的解决方案。
问候
拉斐尔
不幸的是,API 没有给你一个端点来直接列出给定学生的所有作业/提交
但是,您并不是唯一遇到此问题的人,在 Google 的 Public 问题跟踪器上已有针对此功能的 feature request。
我建议您给它一个 "star" 以提高知名度。
与此同时,您确实需要实现 try...catch
语句或条件语句,例如:
if(works[work].assigneeMode == "ALL_STUDENTS" || (works[work].assigneeMode == "INDIVIDUAL_STUDENTS" && works[work].individualStudentsOptions.studentIds.indexOf(idStudent)!=-1))
{
var responseS = Classroom.Courses.CourseWork.StudentSubmissions.list(idCourse, idWork, optionalArgs2);
...
}
我开始使用课堂 API 来增强我们学校的本地应用程序。为了为 class 做一份报告,我想列出所有学生的作业和评分。我使用循环遍历学生的所有课程,然后是每门课程的所有课程作业,然后是每门课程作业的所有提交。这是我使用的一段代码:
function fListWorkStudent(idStudent)
{
// Variables
var pageToken = null;
var optionalArgs =
{
pageToken: pageToken,
courseStates: 'ACTIVE',
studentId: idStudent,
pageSize: 0
};
var optionalArgs2 =
{
pageToken: pageToken,
userId: idStudent,
pageSize: 0
};
// Courses for a student
var response = Classroom.Courses.list(optionalArgs);
var sCourses = response.courses;
if (sCourses.length === 0)
Logger.log("No courses");
else
{
for (course in sCourses)
{
var idCourse=sCourses[course].id;
var nomprof=getUserName(sCourses[course].ownerId);
// Coursework for every course
var responseW = Classroom.Courses.CourseWork.list(idCourse);
var works = responseW.courseWork;
if (works && (works.length > 0))
{
for work in works)
{
var idWork=works[work].id;
// Submissions for every coursework
var responseS = Classroom.Courses.CourseWork.StudentSubmissions.list(idCourse, idWork, optionalArgs2);
var submissions = responseS.studentSubmissions;
if (submissions && submissions.length >0)
{
for (submission in submissions)
{
// Prepare report here
}
}
}
}
}
}
}
此代码的问题在于,当我调用 Classroom.Courses.CourseWork.StudentSubmissions.list(idCourse, idWork, optionalArgs2) 以过滤所选学生的提交时,循环到达未分配给该学生的课程作业,调用失败并出现错误 'classroom.courses.courseWork.studentSubmissions.list; error: Requested entity was not found.' 如果在调用 API 函数之前课程作业未分配给该学生,我可以通过检查循环来解决它,或者可能使用 try..catch 子句来捕获可能的错误,但我想知道是否这个问题有一个更聪明的解决方案。
问候 拉斐尔
不幸的是,API 没有给你一个端点来直接列出给定学生的所有作业/提交
但是,您并不是唯一遇到此问题的人,在 Google 的 Public 问题跟踪器上已有针对此功能的 feature request。
我建议您给它一个 "star" 以提高知名度。
与此同时,您确实需要实现 try...catch
语句或条件语句,例如:
if(works[work].assigneeMode == "ALL_STUDENTS" || (works[work].assigneeMode == "INDIVIDUAL_STUDENTS" && works[work].individualStudentsOptions.studentIds.indexOf(idStudent)!=-1))
{
var responseS = Classroom.Courses.CourseWork.StudentSubmissions.list(idCourse, idWork, optionalArgs2);
...
}