lms .cli .courses .gradebook .get
Get specific entries in a course's gradebook.
usage: python3 -m lms.cli.courses.gradebook.get [-h] [--version]
[--server SERVER]
[--server-type {blackboard,canvas,moodle}]
[--auth-user AUTH_USER]
[--auth-password AUTH_PASSWORD]
[--auth-token AUTH_TOKEN]
[--course COURSE]
[--format {json,table,text}]
[--include-extra-fields]
[--pretty-headers]
[--skip-headers]
[--assignment ASSIGNMENTS]
[--user USERS]
Get specific entries in a course's gradebook.
options:
-h, --help show this help message and exit
--version show program's version number and exit
--course COURSE The course to target for this operation.
--assignment ASSIGNMENTS
Include this assignment in the gradebook (all
assignments are included if this option is not
specified).
--user USERS Include this user in the gradebook (all users are
included if this option is not specified).
server options:
--server SERVER The address of the LMS server to connect to.
--server-type {blackboard,canvas,moodle}
The type of LMS being connected to (this can normally
be guessed from the server address).
authentication options:
--auth-user AUTH_USER
The user to authenticate with.
--auth-password AUTH_PASSWORD
The password to authenticate with.
--auth-token AUTH_TOKEN
The token to authenticate with.
output formatting options:
--format {json,table,text}
The format to display the output as (default: text).
--include-extra-fields
Include non-common (usually LMS-specific) fields in
results (default: False).
--pretty-headers When displaying headers, try to make them look
"pretty" (default: False).
--skip-headers Skip headers when outputting results, will not apply
to all formats (default: False).
1""" 2Get specific entries in a course's gradebook. 3""" 4 5import argparse 6import sys 7 8import lms.backend.instance 9import lms.cli.common 10import lms.cli.parser 11 12def run_cli(args: argparse.Namespace) -> int: 13 """ Run the CLI. """ 14 15 config = args._config 16 17 backend = lms.backend.instance.get_backend(**config) 18 19 course_query = lms.cli.common.check_required_course(backend, config) 20 if (course_query is None): 21 return 1 22 23 assignment_queries = backend.parse_assignment_queries(args.assignments) 24 user_queries = backend.parse_user_queries(args.users) 25 26 gradebook = backend.courses_gradebook_get(course_query, assignment_queries, user_queries) 27 28 output = lms.model.base.base_list_to_output_format([gradebook], args.output_format, 29 skip_headers = args.skip_headers, 30 pretty_headers = args.pretty_headers, 31 include_extra_fields = args.include_extra_fields, 32 extract_single_list = True, 33 ) 34 35 print(output) 36 37 return 0 38 39def main() -> int: 40 """ Get a parser, parse the args, and call run. """ 41 return run_cli(_get_parser().parse_args()) 42 43def _get_parser() -> argparse.ArgumentParser: 44 """ Get the parser. """ 45 46 parser = lms.cli.parser.get_parser(__doc__.strip(), 47 include_output_format = True, 48 include_course = True, 49 ) 50 51 parser.add_argument('--assignment', dest = 'assignments', 52 action = 'append', type = str, default = [], 53 help = 'Include this assignment in the gradebook (all assignments are included if this option is not specified).') 54 55 parser.add_argument('--user', dest = 'users', 56 action = 'append', type = str, default = [], 57 help = 'Include this user in the gradebook (all users are included if this option is not specified).') 58 59 return parser 60 61if (__name__ == '__main__'): 62 sys.exit(main())
def
run_cli(args: argparse.Namespace) -> int:
13def run_cli(args: argparse.Namespace) -> int: 14 """ Run the CLI. """ 15 16 config = args._config 17 18 backend = lms.backend.instance.get_backend(**config) 19 20 course_query = lms.cli.common.check_required_course(backend, config) 21 if (course_query is None): 22 return 1 23 24 assignment_queries = backend.parse_assignment_queries(args.assignments) 25 user_queries = backend.parse_user_queries(args.users) 26 27 gradebook = backend.courses_gradebook_get(course_query, assignment_queries, user_queries) 28 29 output = lms.model.base.base_list_to_output_format([gradebook], args.output_format, 30 skip_headers = args.skip_headers, 31 pretty_headers = args.pretty_headers, 32 include_extra_fields = args.include_extra_fields, 33 extract_single_list = True, 34 ) 35 36 print(output) 37 38 return 0
Run the CLI.
def
main() -> int:
40def main() -> int: 41 """ Get a parser, parse the args, and call run. """ 42 return run_cli(_get_parser().parse_args())
Get a parser, parse the args, and call run.