rubric
एक ऐसा टेंप्लेट होता है जिसका इस्तेमाल शिक्षक, छात्र-छात्राओं के सबमिट किए गए असाइनमेंट को ग्रेड देते समय कर सकते हैं. Classroom API की मदद से, शिक्षक की ओर से इन रूब्रिक को मैनेज किया जा सकता है. साथ ही, छात्र-छात्राओं के सबमिशन पर रूब्रिक के ग्रेड पढ़े जा सकते हैं.
पहली इमेज. Classroom असाइनमेंट में रूब्रिक का सैंपल व्यू.
इस गाइड में, Rubrics API के बुनियादी कॉन्सेप्ट और इसके काम करने के तरीके के बारे में बताया गया है. रूब्रिक के सामान्य स्ट्रक्चर और Classroom के यूज़र इंटरफ़ेस (यूआई) में रूब्रिक के हिसाब से ग्रेडिंग करने के तरीके के बारे में जानने के लिए, सहायता केंद्र के ये लेख पढ़ें.
ज़रूरी शर्तें
हम उम्मीद करते हैं कि आपके पास ये चीज़ें मौजूद हैं:
- Python 3.8.6 या इसके बाद का वर्शन
- pip पैकेज मैनेजमेंट टूल
- एक Google Cloud प्रोजेक्ट.
- Google Classroom चालू किया गया Google Workspace for Education खाता और उसे असाइन किया गया Google Workspace for Education Plus का लाइसेंस. अगर आपके पास डेवलपर डेमो खाता नहीं है, तो अपग्रेड किए गए खाते का अनुरोध किया जा सकता है.
- कम से कम एक छात्र/छात्रा के टेस्ट खाते वाली टेस्ट क्लास. अगर आपके पास ऐसी कोई Classroom क्लास नहीं है जिसका इस्तेमाल टेस्टिंग के लिए किया जा सके, तो यूज़र इंटरफ़ेस (यूआई) में जाकर एक क्लास बनाएं और उसमें एक छात्र-छात्रा को जोड़ें.
डेस्कटॉप ऐप्लिकेशन के लिए क्रेडेंशियल को अनुमति देना
असली उपयोगकर्ता के तौर पर पुष्टि करने और अपने ऐप्लिकेशन में उपयोगकर्ता का डेटा ऐक्सेस करने के लिए, आपको एक या उससे ज़्यादा OAuth 2.0 क्लाइंट आईडी बनाने होंगे. क्लाइंट आईडी का इस्तेमाल, Google के OAuth सर्वर पर किसी एक ऐप्लिकेशन की पहचान करने के लिए किया जाता है. अगर आपका ऐप्लिकेशन कई प्लैटफ़ॉर्म पर काम करता है, तो आपको हर प्लैटफ़ॉर्म के लिए अलग क्लाइंट आईडी बनाना होगा.
- Google Cloud Console में, Google Cloud के क्रेडेंशियल पेज पर जाएं.
- क्रेडेंशियल बनाएं > OAuth क्लाइंट आईडी पर क्लिक करें.
- ऐप्लिकेशन का टाइप > डेस्कटॉप ऐप्लिकेशन पर क्लिक करें.
- नाम फ़ील्ड में, क्रेडेंशियल के लिए कोई नाम टाइप करें. यह नाम सिर्फ़ Google Cloud Console में दिखता है. उदाहरण के लिए, "Rubrics client".
- बनाएं पर क्लिक करें. OAuth क्लाइंट बनाया गया स्क्रीन दिखेगी. इसमें आपका नया क्लाइंट आईडी और क्लाइंट सीक्रेट दिखेगा.
- JSON फ़ाइल डाउनलोड करें पर क्लिक करें. इसके बाद, ठीक है पर क्लिक करें. नया क्रेडेंशियल, OAuth 2.0 क्लाइंट आईडी में दिखता है.
- डाउनलोड की गई JSON फ़ाइल को
credentials.json
के तौर पर सेव करें. इसके बाद, फ़ाइल को अपनी वर्किंग डायरेक्ट्री में ले जाएं. - क्रेडेंशियल बनाएं > एपीआई पासकोड पर क्लिक करें और एपीआई पासकोड नोट करें.
ज़्यादा जानने के लिए, ऐक्सेस क्रेडेंशियल बनाना लेख पढ़ें.
OAuth के दायरे कॉन्फ़िगर करना
आपके प्रोजेक्ट के मौजूदा OAuth स्कोप के आधार पर, आपको अतिरिक्त स्कोप कॉन्फ़िगर करने पड़ सकते हैं.
- OAuth सहमति स्क्रीन पर जाएं.
- स्कोप वाली स्क्रीन पर जाने के लिए, ऐप्लिकेशन में बदलाव करें > सेव करें और जारी रखें पर क्लिक करें.
- स्कोप जोड़ें या हटाएं पर क्लिक करें.
- अगर आपके पास ये स्कोप पहले से नहीं हैं, तो इन्हें जोड़ें:
https://www.googleapis.com/auth/classroom.coursework.students
https://www.googleapis.com/auth/classroom.courses
- इसके बाद, अपडेट करें > सेव करें और जारी रखें > सेव करें और जारी रखें > डैशबोर्ड पर वापस जाएं पर क्लिक करें.
ज़्यादा जानने के लिए, OAuth के लिए सहमति देने वाली स्क्रीन को कॉन्फ़िगर करना लेख पढ़ें.
classroom.coursework.students
स्कोप की मदद से, रूब्रिक (CourseWork
का ऐक्सेस भी मिलता है) को पढ़ने और लिखने का ऐक्सेस मिलता है. वहीं, classroom.courses
स्कोप की मदद से, कोर्स को पढ़ने और लिखने का ऐक्सेस मिलता है.
किसी तरीके के लिए ज़रूरी स्कोप की जानकारी, उस तरीके के रेफ़रंस दस्तावेज़ में दी गई होती है. उदाहरण के लिए, courses.courseWork.rubrics.create
अनुमति के स्कोप देखें. Google APIs के लिए OAuth 2.0 के दायरे में, Classroom के सभी दायरे देखे जा सकते हैं.
सैंपल को कॉन्फ़िगर करना
अपनी वर्किंग डायरेक्ट्री में, Python के लिए Google क्लाइंट लाइब्रेरी इंस्टॉल करें:
pip install --upgrade google-api-python-client google-auth-httplib2 google-auth-oauthlib
main.py
नाम की एक फ़ाइल बनाएं. यह फ़ाइल, क्लाइंट लाइब्रेरी बनाती है और उपयोगकर्ता को अनुमति देती है. इसके लिए, YOUR_API_KEY
की जगह अपने एपीआई पासकोड का इस्तेमाल करें:
import json
import os.path
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
from googleapiclient.errors import HttpError
# If modifying these scopes, delete the file token.json.
SCOPES = ['https://www.googleapis.com/auth/classroom.courses',
'https://www.googleapis.com/auth/classroom.coursework.students']
def build_authenticated_service(api_key):
"""Builds the Classroom service."""
creds = None
# The file token.json stores the user's access and refresh tokens, and is
# created automatically when the authorization flow completes for the first
# time.
if os.path.exists('token.json'):
creds = Credentials.from_authorized_user_file('token.json', SCOPES)
# If there are no (valid) credentials available, let the user log in.
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)
# Save the credentials for the next run.
with open('token.json', 'w') as token:
token.write(creds.to_json())
try:
# Build the Classroom service.
service = build(
serviceName="classroom",
version="v1",
credentials=creds,
discoveryServiceUrl=f"https://classroom.googleapis.com/$discovery/rest?labels=DEVELOPER_PREVIEW&key={api_key}")
return service
except HttpError as error:
print('An error occurred: %s' % error)
if __name__ == '__main__':
service = build_authenticated_service(YOUR_API_KEY)
python main.py
का इस्तेमाल करके स्क्रिप्ट चलाएं. आपको साइन इन करने और OAuth स्कोप के लिए सहमति देने के लिए कहा जाएगा.
एक असाइनमेंट बनाएं
रूब्रिक, किसी असाइनमेंट या CourseWork
से जुड़ा होता है. साथ ही, यह सिर्फ़ उस CourseWork
के हिसाब से काम करता है. रूब्रिक सिर्फ़ उस Google Cloud प्रोजेक्ट से बनाए जा सकते हैं जिसने पैरंट CourseWork
आइटम बनाया है. इस गाइड के लिए, स्क्रिप्ट की मदद से नया CourseWork
असाइनमेंट बनाएं.
main.py
में यह जोड़ें:
def get_latest_course(service):
"""Retrieves the last created course."""
try:
response = service.courses().list(pageSize=1).execute()
courses = response.get("courses", [])
if not courses:
print("No courses found. Did you remember to create one in the UI?")
return
course = courses[0]
return course
except HttpError as error:
print(f"An error occurred: {error}")
return error
def create_coursework(service, course_id):
"""Creates and returns a sample coursework."""
try:
coursework = {
"title": "Romeo and Juliet analysis.",
"description": """Write a paper arguing that Romeo and Juliet were
time travelers from the future.""",
"workType": "ASSIGNMENT",
"state": "PUBLISHED",
}
coursework = service.courses().courseWork().create(
courseId=course_id, body=coursework).execute()
return coursework
except HttpError as error:
print(f"An error occurred: {error}")
return error
अब main.py
को अपडेट करें, ताकि आपने अभी जो टेस्ट क्लास बनाई है उसका course_id
वापस मिल सके. इसके बाद, एक नया सैंपल असाइनमेंट बनाएं और असाइनमेंट का coursework_id
वापस पाएं:
if __name__ == '__main__':
service = build_authenticated_service(YOUR_API_KEY)
course = get_latest_course(service)
course_id = course.get("id")
course_name = course.get("name")
print(f"'{course_name}' course ID: {course_id}")
coursework = create_coursework(service, course_id)
coursework_id = coursework.get("id")
print(f"Assignment created with ID {coursework_id}")
#TODO(developer): Save the printed course and coursework IDs.
course_id
और coursework_id
को सेव करें. इनकी ज़रूरत सभी रूब्रिक CRUD कार्रवाइयों के लिए होती है.
अब आपको Classroom में एक सैंपल CourseWork
दिखेगा.
दूसरी इमेज. Classroom में असाइनमेंट का सैंपल व्यू.
उपयोगकर्ता के लिए ज़रूरी शर्तें देखना
रूब्रिक बनाने और अपडेट करने के लिए, अनुरोध करने वाले उपयोगकर्ता और कोर्स के मालिक, दोनों के पास Google Workspace for Education Plus का लाइसेंस होना चाहिए. Classroom, उपयोगकर्ता के लिए ज़रूरी शर्तें पूरी करने वाले एंडपॉइंट का इस्तेमाल करता है. इससे डेवलपर यह तय कर पाते हैं कि उपयोगकर्ता के पास किन सुविधाओं का ऐक्सेस है.
main.py
को अपडेट करें और चलाएं, ताकि यह पुष्टि की जा सके कि आपके टेस्ट खाते के पास रूब्रिक की सुविधा का ऐक्सेस है:
if __name__ == '__main__':
service = build_authenticated_service(YOUR_API_KEY)
capability = service.userProfiles().checkUserCapability(
userId='me',
# Specify the preview version. checkUserCapability is
# supported in V1_20240930_PREVIEW and later.
previewVersion="V1_20240930_PREVIEW",
capability="CREATE_RUBRIC").execute()
if not capability.get('allowed'):
print('User ineligible for rubrics creation.')
# TODO(developer): in a production app, this signal could be used to
# proactively hide any rubrics related features from users or encourage
# them to upgrade to the appropriate license.
else:
print('User eligible for rubrics creation.')
रूब्रिक बनाना
अब आपके पास रूब्रिक मैनेज करने का विकल्प है.
रूब्रिक को CourseWork
पर बनाया जा सकता है. इसके लिए, create()
कॉल का इस्तेमाल किया जाता है. इसमें पूरा रूब्रिक ऑब्जेक्ट शामिल होता है. साथ ही, इसमें मानदंड और लेवल के लिए आईडी प्रॉपर्टी शामिल नहीं होती हैं. ये प्रॉपर्टी, रूब्रिक बनाते समय जनरेट होती हैं.
main.py
में यह फ़ंक्शन जोड़ें:
def create_rubric(service, course_id, coursework_id):
"""Creates an example rubric on a coursework."""
try:
body = {
"criteria": [
{
"title": "Argument",
"description": "How well structured your argument is.",
"levels": [
{"title": "Convincing",
"description": "A compelling case is made.", "points": 30},
{"title": "Passable",
"description": "Missing some evidence.", "points": 20},
{"title": "Needs Work",
"description": "Not enough strong evidence..", "points": 0},
]
},
{
"title": "Spelling",
"description": "How well you spelled all the words.",
"levels": [
{"title": "Perfect",
"description": "No mistakes.", "points": 20},
{"title": "Great",
"description": "A mistake or two.", "points": 15},
{"title": "Needs Work",
"description": "Many mistakes.", "points": 5},
]
},
{
"title": "Grammar",
"description": "How grammatically correct your sentences are.",
"levels": [
{"title": "Perfect",
"description": "No mistakes.", "points": 20},
{"title": "Great",
"description": "A mistake or two.", "points": 15},
{"title": "Needs Work",
"description": "Many mistakes.", "points": 5},
]
},
]
}
rubric = service.courses().courseWork().rubrics().create(
courseId=course_id, courseWorkId=coursework_id, body=body
).execute()
print(f"Rubric created with ID {rubric.get('id')}")
return rubric
except HttpError as error:
print(f"An error occurred: {error}")
return error
इसके बाद, उदाहरण के तौर पर रूब्रिक बनाने के लिए, main.py
को अपडेट करें और चलाएं. इसके लिए, पहले से मौजूद Course
और CourseWork
आईडी का इस्तेमाल करें:
if __name__ == '__main__':
service = build_authenticated_service(YOUR_API_KEY)
capability = service.userProfiles().checkUserCapability(
userId='me',
# Specify the preview version. checkUserCapability is
# supported in V1_20240930_PREVIEW and later.
previewVersion="V1_20240930_PREVIEW",
capability="CREATE_RUBRIC").execute()
if not capability.get('allowed'):
print('User ineligible for rubrics creation.')
# TODO(developer): in a production app, this signal could be used to
# proactively hide any rubrics related features from users or encourage
# them to upgrade to the appropriate license.
else:
rubric = create_rubric(service, YOUR_COURSE_ID, YOUR_COURSEWORK_ID)
print(json.dumps(rubric, indent=4))
रूब्रिक के बारे में कुछ ज़रूरी बातें:
- मानदंड और लेवल का क्रम, Classroom के यूज़र इंटरफ़ेस (यूआई) में दिखता है.
- स्कोर किए गए लेवल (जिनमें
points
प्रॉपर्टी होती है) को पॉइंट के हिसाब से बढ़ते या घटते क्रम में लगाया जाना चाहिए. इन्हें रैंडम तरीके से नहीं लगाया जा सकता. - शिक्षक, यूज़र इंटरफ़ेस (यूआई) में जाकर, मानदंड और स्कोर किए गए लेवल (लेकिन स्कोर नहीं किए गए लेवल) को फिर से क्रम से लगा सकते हैं. इससे डेटा में उनका क्रम बदल जाता है.
रूब्रिक के स्ट्रक्चर से जुड़ी अन्य चेतावनियों के बारे में जानने के लिए, सीमाएं देखें.
यूज़र इंटरफ़ेस (यूआई) पर वापस जाने पर, आपको असाइनमेंट में रूब्रिक दिखेगा.
तीसरी इमेज. Classroom असाइनमेंट में रूब्रिक का सैंपल व्यू.
रूब्रिक पढ़ना
रूब्रिक को स्टैंडर्ड list()
और get()
तरीकों से पढ़ा जा सकता है.
किसी असाइनमेंट में ज़्यादा से ज़्यादा एक रूब्रिक हो सकता है. इसलिए, list()
का इस्तेमाल करना थोड़ा मुश्किल लग सकता है. हालांकि, अगर आपके पास रूब्रिक आईडी नहीं है, तो यह आपके लिए मददगार हो सकता है. अगर किसी CourseWork
से कोई रूब्रिक नहीं जुड़ा है, तो list()
का जवाब खाली होता है.
main.py
में यह फ़ंक्शन जोड़ें:
def get_rubric(service, course_id, coursework_id):
"""
Get the rubric on a coursework. There can only be at most one.
Returns null if there is no rubric.
"""
try:
response = service.courses().courseWork().rubrics().list(
courseId=course_id, courseWorkId=coursework_id
).execute()
rubrics = response.get("rubrics", [])
if not rubrics:
print("No rubric found for this assignment.")
return
rubric = rubrics[0]
return rubric
except HttpError as error:
print(f"An error occurred: {error}")
return error
आपने जो रूब्रिक जोड़ा है उसे फ़ेच करने के लिए, main.py
को अपडेट करें और चलाएं:
if __name__ == '__main__':
service = build_authenticated_service(YOUR_API_KEY)
rubric = get_rubric(service, YOUR_COURSE_ID, YOUR_COURSEWORK_ID)
print(json.dumps(rubric, indent=4))
#TODO(developer): Save the printed rubric ID.
रूब्रिक में दी गई id
प्रॉपर्टी को नोट कर लें, ताकि बाद के चरणों में इसका इस्तेमाल किया जा सके.
Get()
का इस्तेमाल करने के लिए, रूब्रिक आईडी होना ज़रूरी है. फ़ंक्शन में get()
का इस्तेमाल करने पर, यह ऐसा दिख सकता है:
def get_rubric(service, course_id, coursework_id, rubric_id):
"""
Get the rubric on a coursework. There can only be at most one.
Returns a 404 if there is no rubric.
"""
try:
rubric = service.courses().courseWork().rubrics().get(
courseId=course_id,
courseWorkId=coursework_id,
id=rubric_id
).execute()
return rubric
except HttpError as error:
print(f"An error occurred: {error}")
return error
अगर कोई रूब्रिक मौजूद नहीं है, तो यह तरीका 404 गड़बड़ी दिखाता है.
किसी रूब्रिक को अपडेट करना
रूब्रिक में बदलाव करने के लिए, patch()
कॉल का इस्तेमाल किया जाता है. रूब्रिक का स्ट्रक्चर जटिल होने की वजह से, अपडेट करने के लिए read-modify-write पैटर्न का इस्तेमाल करना ज़रूरी है. इसमें पूरी criteria
प्रॉपर्टी को बदल दिया जाता है.
अपडेट करने के ये नियम हैं:
- आईडी के बिना जोड़े गए मानदंड या लेवल को जोड़े गए मानदंड या लेवल माना जाता है.
- पहले से मौजूद मानदंड या लेवल नहीं दिख रहे हैं, तो उन्हें मिटा दिया गया माना जाता है.
- मौजूदा आईडी वाले, लेकिन बदले गए डेटा के साथ मानदंड या लेवल को बदलाव माना जाता है. जिन प्रॉपर्टी में बदलाव नहीं किया गया है उन्हें पहले जैसा ही रखा जाता है.
- नए या अज्ञात आईडी के साथ दिए गए मानदंड या लेवल को गड़बड़ियां माना जाता है.
- नई शर्तों और लेवल के क्रम को, नए यूज़र इंटरफ़ेस (यूआई) का क्रम माना जाता है. हालांकि, इसमें ऊपर बताई गई सीमाएं लागू होती हैं.
रूब्रिक को अपडेट करने के लिए फ़ंक्शन जोड़ें:
def update_rubric(service, course_id, coursework_id, rubric_id, body):
"""
Updates the rubric on a coursework.
"""
try:
rubric = service.courses().courseWork().rubrics().patch(
courseId=course_id,
courseWorkId=coursework_id,
id=rubric_id,
body=body,
updateMask='criteria'
).execute()
return rubric
except HttpError as error:
print(f"An error occurred: {error}")
return error
इस उदाहरण में, criteria
फ़ील्ड में बदलाव करने के लिए updateMask
का इस्तेमाल किया गया है.
इसके बाद, ऊपर बताई गई हर अपडेट की
शर्त के लिए, main.py
में बदलाव करें:
if __name__ == '__main__':
service = build_authenticated_service(YOUR_API_KEY)
capability = service.userProfiles().checkUserCapability(
userId='me',
# Specify the preview version. checkUserCapability is
# supported in V1_20240930_PREVIEW and later.
previewVersion="V1_20240930_PREVIEW",
capability="CREATE_RUBRIC").execute()
if not capability.get('allowed'):
print('User ineligible for rubrics creation.')
# TODO(developer): in a production app, this signal could be used to
# proactively hide any rubrics related features from users or encourage
# them to upgrade to the appropriate license.
else:
# Get the latest rubric.
rubric = get_rubric(service, YOUR_COURSE_ID, YOUR_COURSEWORK_ID)
criteria = rubric.get("criteria")
"""
The "criteria" property should look like this:
[
{
"id": "NkEyMdMyMzM2Nxkw",
"title": "Argument",
"description": "How well structured your argument is.",
"levels": [
{
"id": "NkEyMdMyMzM2Nxkx",
"title": "Convincing",
"description": "A compelling case is made.",
"points": 30
},
{
"id": "NkEyMdMyMzM2Nxky",
"title": "Passable",
"description": "Missing some evidence.",
"points": 20
},
{
"id": "NkEyMdMyMzM2Nxkz",
"title": "Needs Work",
"description": "Not enough strong evidence..",
"points": 0
}
]
},
{
"id": "NkEyMdMyMzM2Nxk0",
"title": "Spelling",
"description": "How well you spelled all the words.",
"levels": [...]
},
{
"id": "NkEyMdMyMzM2Nxk4",
"title": "Grammar",
"description": "How grammatically correct your sentences are.",
"levels": [...]
}
]
"""
# Make edits. This example will make one of each type of change.
# Add a new level to the first criteria. Levels must remain sorted by
# points.
new_level = {
"title": "Profound",
"description": "Truly unique insight.",
"points": 50
}
criteria[0]["levels"].insert(0, new_level)
# Remove the last criteria.
del criteria[-1]
# Update the criteria titles with numeric prefixes.
for index, criterion in enumerate(criteria):
criterion["title"] = f"{index}: {criterion['title']}"
# Resort the levels from descending to ascending points.
for criterion in criteria:
criterion["levels"].sort(key=lambda level: level["points"])
# Update the rubric with a patch call.
new_rubric = update_rubric(
service, YOUR_COURSE_ID, YOUR_COURSEWORK_ID, YOUR_RUBRIC_ID, rubric)
print(json.dumps(new_rubric, indent=4))
अब Classroom में शिक्षक को बदलाव दिखने चाहिए.
चौथी इमेज. अपडेट किए गए रूब्रिक का व्यू.
रूब्रिक के हिसाब से ग्रेड किए गए सबमिशन देखना
फ़िलहाल, एपीआई की मदद से छात्र-छात्राओं के सबमिशन को रूब्रिक के हिसाब से ग्रेड नहीं दिया जा सकता. हालांकि, Classroom के यूज़र इंटरफ़ेस (यूआई) में, रूब्रिक के हिसाब से ग्रेड किए गए सबमिशन के लिए, रूब्रिक के ग्रेड देखे जा सकते हैं.
Classroom के यूज़र इंटरफ़ेस (यूआई) में छात्र या छात्रा के तौर पर, अपने सैंपल असाइनमेंट को पूरा करें और उसे सबमिट करें. इसके बाद, शिक्षक के तौर पर रूब्रिक का इस्तेमाल करके, असाइनमेंट को मैन्युअल तरीके से ग्रेड दें.
पांचवी इमेज. ग्रेड देते समय, शिक्षक को दिखने वाला रूब्रिक.
StudentSubmissions
को रूब्रिक के हिसाब से ग्रेड दिया गया है. इनमें दो नई प्रॉपर्टी हैं: draftRubricGrades
और assignedRubricGrades
. ये प्रॉपर्टी, ड्राफ़्ट और असाइन की गई ग्रेडिंग की स्थितियों के दौरान शिक्षक की ओर से चुने गए पॉइंट और लेवल दिखाती हैं.
ग्रेड किए गए सबमिशन देखने के लिए, मौजूदा studentSubmissions.get()
और
studentSubmissions.list()
तरीकों का इस्तेमाल किया जा सकता है.
छात्र-छात्राओं के सबमिशन की सूची बनाने के लिए, main.py
में यह फ़ंक्शन जोड़ें:
def get_latest_submission(service, course_id, coursework_id):
"""Retrieves the last submission for an assignment."""
try:
response = service.courses().courseWork().studentSubmissions().list(
courseId = course_id,
courseWorkId = coursework_id,
pageSize=1
).execute()
submissions = response.get("studentSubmissions", [])
if not submissions:
print(
"""No submissions found. Did you remember to turn in and grade
the assignment in the UI?""")
return
submission = submissions[0]
return submission
except HttpError as error:
print(f"An error occurred: {error}")
return error
इसके बाद, सबमिट किए गए असाइनमेंट के ग्रेड देखने के लिए, main.py
को अपडेट करें और चलाएँ.
if __name__ == '__main__':
service = build_authenticated_service(YOUR_API_KEY)
submission = get_latest_submission(
service, YOUR_COURSE_ID, YOUR_COURSEWORK_ID)
print(json.dumps(submission, indent=4))
draftRubricGrades
और assignedRubricGrades
में यह कॉन्टेंट शामिल है:
- यह रूब्रिक के लिए सुझाई गई शर्त का
criterionId
है. points
शिक्षक ने हर मानदंड के लिए असाइन किया है. यह चुने गए लेवल के हिसाब से हो सकता है. हालांकि, शिक्षक के पास इसे बदलने का विकल्प भी होता है.- हर शर्त के लिए चुने गए लेवल का
levelId
. अगर शिक्षक ने कोई लेवल नहीं चुना है, लेकिन फिर भी मानदंड के लिए पॉइंट असाइन किए हैं, तो यह फ़ील्ड मौजूद नहीं होता.
इन सूचियों में सिर्फ़ उन मानदंडों की एंट्री होती हैं जिनके लिए शिक्षक ने कोई लेवल चुना है या पॉइंट सेट किए हैं. उदाहरण के लिए, अगर कोई शिक्षक ग्रेडिंग के दौरान सिर्फ़ एक मानदंड के साथ इंटरैक्ट करता है, तो draftRubricGrades
और assignedRubricGrades
में सिर्फ़ एक आइटम होगा. भले ही, रूब्रिक में कई मानदंड हों.
किसी रूब्रिक को मिटाना
स्टैंडर्ड delete()
अनुरोध करके, रूब्रिक को मिटाया जा सकता है. यहां दिए गए कोड में, पूरी जानकारी देने के लिए एक फ़ंक्शन का उदाहरण दिया गया है. हालांकि, ग्रेडिंग पहले ही शुरू हो चुकी है. इसलिए, मौजूदा रूब्रिक को मिटाया नहीं जा सकता:
def delete_rubric(service, course_id, coursework_id, rubric_id):
"""Deletes the rubric on a coursework."""
try:
service.courses().courseWork().rubrics().delete(
courseId=course_id,
courseWorkId=coursework_id,
id=rubric_id
).execute()
except HttpError as error:
print(f"An error occurred: {error}")
return error
रूब्रिक एक्सपोर्ट और इंपोर्ट करना
शिक्षकों के दोबारा इस्तेमाल करने के लिए, रूब्रिक को Google Sheets में मैन्युअल तरीके से एक्सपोर्ट किया जा सकता है.
कोड में रूब्रिक की शर्तें तय करने के अलावा, एक्सपोर्ट की गई इन शीट से रूब्रिक बनाए और अपडेट किए जा सकते हैं. इसके लिए, रूब्रिक के मुख्य हिस्से में sourceSpreadsheetId
के बजाय criteria
तय करें:
def create_rubric_from_sheet(service, course_id, coursework_id, sheet_id):
"""Creates an example rubric on a coursework."""
try:
body = {
"sourceSpreadsheetId": sheet_id
}
rubric = service.courses().courseWork().rubrics().create(
courseId=course_id, courseWorkId=coursework_id, body=body
).execute()
print(f"Rubric created with ID {rubric.get('id')}")
return rubric
except HttpError as error:
print(f"An error occurred: {error}")
return error