ตั้งค่าและอัปเดตคะแนน

คู่มือนี้มีตัวอย่างโค้ดที่เกี่ยวข้องกับการให้คะแนนสำหรับ Google Classroom API อ่านคู่มือการให้คะแนนเพื่อทำความคุ้นเคยกับแนวคิดการให้คะแนนใน Classroom

กำหนดคะแนนสำหรับงานที่นักเรียนส่ง

แหล่งข้อมูล StudentSubmission มี 2 ช่องสำหรับจัดเก็บคะแนน ได้แก่ assignedGrade ซึ่งเป็นคะแนนที่รายงานให้นักเรียนทราบ และ draftGrade ซึ่งเป็นคะแนนที่ยังไม่แน่นอนที่ครูเท่านั้นที่เห็น ระบบจะอัปเดตช่องเหล่านี้โดยใช้ courses.courseWork.studentSubmissions.patch

Python

studentSubmission = {
  'assignedGrade': 99,
  'draftGrade': 80
}

service.courses().courseWork().studentSubmissions().patch(
    courseId=course_id,
    courseWorkId=coursework_id,
    id=studentsubmission_id,
    updateMask='assignedGrade,draftGrade',
    body=studentSubmission).execute()

Java

classroom/snippets/src/main/java/PatchStudentSubmission.java
StudentSubmission studentSubmission = null;
try {
  // Updating the draftGrade and assignedGrade fields for the specific student submission.
  StudentSubmission content =
      service
          .courses()
          .courseWork()
          .studentSubmissions()
          .get(courseId, courseWorkId, id)
          .execute();
  content.setAssignedGrade(90.00);
  content.setDraftGrade(80.00);

  // The updated studentSubmission object is returned with the new draftGrade and assignedGrade.
  studentSubmission =
      service
          .courses()
          .courseWork()
          .studentSubmissions()
          .patch(courseId, courseWorkId, id, content)
          .set("updateMask", "draftGrade,assignedGrade")
          .execute();

  /* Prints the updated student submission. */
  System.out.printf(
      "Updated student submission draft grade (%s) and assigned grade (%s).\n",
      studentSubmission.getDraftGrade(), studentSubmission.getAssignedGrade());
} catch (GoogleJsonResponseException e) {
  // TODO (developer) - handle error appropriately
  GoogleJsonError error = e.getDetails();
  if (error.getCode() == 404) {
    System.out.printf(
        "The courseId (%s), courseWorkId (%s), or studentSubmissionId (%s) does "
            + "not exist.\n",
        courseId, courseWorkId, id);
  } else {
    throw e;
  }
} catch (Exception e) {
  throw e;
}
return studentSubmission;

เมื่อใช้ UI ของ Classroom ครูจะกำหนดคะแนนไม่ได้จนกว่าจะบันทึกคะแนนฉบับร่างก่อน จากนั้นคุณก็สามารถส่งคะแนนที่มอบหมายคืนให้กับนักเรียนได้ แอปพลิเคชันสามารถให้คะแนนงานของนักเรียนได้ 2 วิธี ดังนี้

  • มอบหมายเฉพาะ draftGrade ซึ่งมีประโยชน์ เช่น ช่วยให้ครูตรวจสอบคะแนนด้วยตนเองก่อนที่จะสรุปคะแนน นักเรียนจะไม่เห็นคะแนนฉบับร่าง

  • มอบหมายทั้ง draftGrade และ assignedGrade เพื่อให้คะแนนงานอย่างเต็มรูปแบบ

อ่านคะแนนที่ได้รับมอบหมาย

คุณสามารถแสดงคะแนนทั้งหมดสำหรับงานในหลักสูตรที่เฉพาะเจาะจงได้โดยดูออบเจ็กต์คำตอบของเมธอด courses.courseWork.studentSubmissions.list ดังนี้

Python

response = coursework.studentSubmissions().list(
    courseId=course_id,
    courseWorkId=coursework_id,
    pageSize=10 # optionally include `pageSize` to restrict the number of student submissions included in the response.
).execute()
submissions.extend(response.get('studentSubmissions', []))

if not submissions:
    print('No student submissions found.')

print('Student Submissions:')

for submission in submissions:
    print(f"Submitted at:"
          f"{(submission.get('userId'), submission.get('assignedGrade'))}")

Java

classroom/snippets/src/main/java/ListStudentSubmissions.java
  ListStudentSubmissionsResponse response =
      service
          .courses()
          .courseWork()
          .studentSubmissions()
          .list(courseId, courseWorkId)
          .setPageToken(pageToken)
          .execute();

  /* Ensure that the response is not null before retrieving data from it to avoid errors. */
  if (response.getStudentSubmissions() != null) {
    studentSubmissions.addAll(response.getStudentSubmissions());
    pageToken = response.getNextPageToken();
  }
} while (pageToken != null);

if (studentSubmissions.isEmpty()) {
  System.out.println("No student submissions found.");
} else {
  for (StudentSubmission submission : studentSubmissions) {
    System.out.printf(
        "User ID %s, Assigned grade: %s\n",
        submission.getUserId(), submission.getAssignedGrade());
  }
}

กำหนดคะแนนโดยรวมของหลักสูตร

Classroom API ไม่อนุญาตให้นักพัฒนาแอปอ่านหรือเขียนคะแนนรวมของหลักสูตร แต่คุณคำนวณคะแนนรวมโดยใช้โปรแกรมได้ บทความในศูนย์ช่วยเหลือเกี่ยวกับการตั้งค่าการให้คะแนนมีเคล็ดลับเกี่ยวกับการคำนวณนี้ แหล่งข้อมูลCourseมีช่อง gradebookSettings ที่ช่วยคุณคำนวณ

หากต้องการคำนวณคะแนนโดยรวม โปรดอ่านคำแนะนำบางส่วนเพื่อทบทวนสิ่งที่ควรทราบเมื่อจัดการงานที่ทำล่าช้า งานที่ทำไม่ทันเนื่องจากมีเหตุอันควร และงานที่ทำไม่ทัน

จัดการสถานะการตอบกลับของนักเรียน

นักเรียนสามารถยกเลิกการส่ง ส่ง หรือส่งคืนคำตอบได้ ช่องสถานะใน StudentSubmission ระบุสถานะปัจจุบัน หากต้องการเปลี่ยนสถานะ ให้เรียกใช้วิธีการใดวิธีการหนึ่งต่อไปนี้

  • courses.courseWork.studentSubmissions.turnIn: เฉพาะนักเรียนที่เป็นเจ้าของไฟล์ StudentSubmission เท่านั้นที่ส่งงานได้
  • courses.courseWork.studentSubmissions.reclaim: เฉพาะนักเรียนที่เป็นเจ้าของStudentSubmissionเท่านั้นที่จะอ้างสิทธิ์ได้ คุณจะอ้างสิทธิ์ไฟล์ที่ส่งได้ก็ต่อเมื่อส่งไฟล์แล้วเท่านั้น
  • courses.courseWork.studentSubmissions.return: เฉพาะครูในหลักสูตรเท่านั้นที่จะส่งStudentSubmissionคืนได้ คุณส่งงานคืนได้ก็ต่อเมื่อนักเรียนส่งงานแล้วเท่านั้น

วิธีการทั้งหมดนี้ยอมรับพารามิเตอร์ body ว่าง เช่น

Python

service.courses().courseWork().studentSubmission().turnIn(
    courseId=course_id,
    courseWorkId=coursework_id,
    id=studentsubmission_id,
    body={}).execute()

Java

classroom/snippets/src/main/java/ReturnStudentSubmission.java
try {
  service
      .courses()
      .courseWork()
      .studentSubmissions()
      .classroomReturn(courseId, courseWorkId, id, null)
      .execute();
} catch (GoogleJsonResponseException e) {
  // TODO (developer) - handle error appropriately
  GoogleJsonError error = e.getDetails();
  if (error.getCode() == 404) {
    System.out.printf(
        "The courseId (%s), courseWorkId (%s), or studentSubmissionId (%s) does "
            + "not exist.\n",
        courseId, courseWorkId, id);
  } else {
    throw e;
  }
} catch (Exception e) {
  throw e;
}

ไฟล์แนบของส่วนเสริมการให้คะแนน

หากเป็นนักพัฒนาส่วนเสริมของ Classroom คุณจะกำหนดคะแนนสำหรับไฟล์แนบของส่วนเสริมแต่ละรายการและกำหนดค่าคะแนนให้ครูมองเห็นได้เมื่อตรวจสอบงานของนักเรียน ดูข้อมูลเพิ่มเติมได้ในคำแนะนำไฟล์แนบประเภทกิจกรรมและการส่งคะแนนคืน