aboutsummaryrefslogtreecommitdiff
path: root/convertGradescopeDB.tcl
blob: 29e83074431d19bbb866bd097e60afd30711f604 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
#!/bin/sh
# (C) 2011 by Eugeniy Mikhailov, <evgmik@gmail.com>
# vim:set ft=tcl: \
exec tclsh "$0" "$@"

set reviewersToSkip [list "Michael Kordosky" "Konstantinos Orginos"]

package require sqlite3
package require md5
package require json::write

source ./GradeBook_lib.tcl


sqlite3 dbScoresAndNotes  csvExport.db -readonly true
sqlite3 db    /run/user/1000/2021_physics.db

proc iferror { err errStat {eval_str {""} }} {
	#return; # comment out when debugging
	if { $err } {
		puts "Error: $errStat"
		if { $eval_str ne "" } {
			puts "For query: $eval_str"
		}
		return true
	}
	return false
}


set rank [list Individual Ranking]
set ReviewerName [list Application Review: Owner Name] 
set type [list Application Review Type]
set fname [list First Name]
set lname [list Last Name]
set idnum [list SID]

## create table id it does not exist
CreateCourseInfoTable db
CreateGradesTable db
CreateAccessRightsTable db
CreateGradesCategoryTable db


## Pull out students related info
set eval_str [concat SELECT * FROM 'applicants_raw']
set err [catch {
	dbScoresAndNotes eval $eval_str v {
		#AddUserNonWeb $fname $lname $email student $id $sect
		AddUserNonWeb $v($fname) $v($lname) $v(Email) student $v($idnum) 1
		#addStudent db $v($idnum)  $v(Contact)
		}
	} errStat ]
iferror $err $errStat

set hwPrefix "Homework"
set labPrefix "Lab"
## Fill the grades
set eval_str [concat SELECT * FROM 'applicants_raw']
set err [catch {
	dbScoresAndNotes eval $eval_str v {
		set all_column_names [getColListFromTable GradesTable]
		foreach col  $v(*) {
			#puts $col
			set result [regexp -nocase {Homework [0-9]+$} $col match]
			if { $result } {
				puts " -> $col"
				if { $CategoryWeightedTolalName ni $all_column_names } {
				
					AddColumnNonWeb $col HomeWork 20
				}
				#UpdateColumnWithValueInTableWhere GradesTable $col $v($col) IdNum $v($idnum)
			}
		}
	}
	} errStat ]
iferror $err $errStat

## Pull student decision
#set eval_str [concat SELECT * FROM 'applicants_raw' where \`$type\` LIKE \'%GAS Physics Student Intent to Enroll%\']
#set err [catch {
	#dbScoresAndNotes eval $eval_str v {
		#addStudent db $v($idnum)  $v(Contact)
		#if { $v(Decision) ne "" } {
			#UpdateColumnWithValueInTableWhere db GradesTable StudentResponse $v(Decision) IdNum $v($idnum)
		#}
		#}
	#} errStat ]
#iferror $err $errStat