reworking the script to work with COMMLD570A (editted)
this commit was editted to not include student details - new manual version of the coldcallbot - minor tweaks to make things less discord specific - changes for new URLs, filenames, and such
This commit is contained in:
parent
0d3bd05ff2
commit
d8e662b5c3
@ -1,4 +1,4 @@
|
||||
myuw <- read.csv("myuw-COM_482_A_autumn_2020_students.csv")
|
||||
myuw <- read.csv("myuw-COMMLD_570_A_spring_2021_students.csv")
|
||||
gs <- read.delim("student_information.tsv")
|
||||
|
||||
## these are students who dropped the class (should be empty)
|
||||
@ -10,14 +10,14 @@ myuw[!myuw$StudentNo %in% gs$Your.UW.student.number,]
|
||||
## read all the folks who have been called and see who is missing from
|
||||
## the google sheet
|
||||
|
||||
call.list <- unlist(lapply(list.files(".", pattern="^attendance-.*tsv$"), function (x) {
|
||||
d <- read.delim(x)
|
||||
strsplit(d[[2]], ",")
|
||||
})
|
||||
)
|
||||
present <- unique(call.list)
|
||||
present[!present %in% gs[["Your.username.on.the.class.Discord.server"]]]
|
||||
## call.list <- unlist(lapply(list.files(".", pattern="^attendance-.*tsv$"), function (x) {
|
||||
## d <- read.delim(x)
|
||||
## strsplit(d[[2]], ",")
|
||||
## })
|
||||
## )
|
||||
## present <- unique(call.list)
|
||||
## present[!present %in% gs[["Your.username.on.the.class.Discord.server"]]]
|
||||
|
||||
## and never attended class..
|
||||
gs[["Your.username.on.the.class.Discord.server"]][!gs[["Your.username.on.the.class.Discord.server"]] %in% present]
|
||||
## gs[["Your.username.on.the.class.Discord.server"]][!gs[["Your.username.on.the.class.Discord.server"]] %in% present]
|
||||
|
||||
|
||||
30
coldcall.py
30
coldcall.py
@ -8,19 +8,21 @@ from csv import DictReader
|
||||
|
||||
import os.path
|
||||
import re
|
||||
import discord
|
||||
|
||||
class ColdCall():
|
||||
def __init__ (self):
|
||||
def __init__ (self, record_attendance=True):
|
||||
self.today = str(datetime.date(datetime.now()))
|
||||
# how much less likely should it be that a student is called upon?
|
||||
self.weight = 2
|
||||
self.record_attendance = record_attendance
|
||||
|
||||
# filenames
|
||||
self.__fn_studentinfo = "data/student_information.tsv"
|
||||
self.__fn_daily_calllist = f"data/call_list-{self.today}.tsv"
|
||||
self.__fn_daily_attendance = f"data/attendance-{self.today}.tsv"
|
||||
|
||||
self.preferred_names = self.__get_preferred_names()
|
||||
|
||||
def __load_prev_questions(self):
|
||||
previous_questions = defaultdict(int)
|
||||
|
||||
@ -29,21 +31,24 @@ class ColdCall():
|
||||
with open(f"./data/{fn}", 'r') as f:
|
||||
for row in DictReader(f, delimiter="\t"):
|
||||
if not row["answered"] == "FALSE":
|
||||
previous_questions[row["discord_name"]] += 1
|
||||
previous_questions[row["unique_name"]] += 1
|
||||
|
||||
return previous_questions
|
||||
|
||||
def __get_preferred_name(self, selected_student):
|
||||
# translate the discord name into the preferred students name,
|
||||
# if possible, otherwise return the discord name
|
||||
def __get_preferred_names(self):
|
||||
# translate the unique name into the preferred students name,
|
||||
# if possible, otherwise return the unique name
|
||||
|
||||
preferred_names = {}
|
||||
with open(self.__fn_studentinfo, 'r') as f:
|
||||
for row in DictReader(f, delimiter="\t"):
|
||||
preferred_names[row["Your username on the class Discord server"]] = row["Name you'd like to go by in class"]
|
||||
preferred_names[row["Your username on the class Teams server"]] = row["Name you'd like to go by in class"]
|
||||
|
||||
if selected_student in preferred_names:
|
||||
return preferred_names[selected_student]
|
||||
return(preferred_names)
|
||||
|
||||
def __get_preferred_name(self, selected_student):
|
||||
if selected_student in self.preferred_names:
|
||||
return self.preferred_names[selected_student]
|
||||
else:
|
||||
return None
|
||||
|
||||
@ -59,7 +64,7 @@ class ColdCall():
|
||||
weights[s] = weights[s] / self.weight
|
||||
|
||||
# choose one student from the weighted list
|
||||
print(weights)
|
||||
# print(weights) # DEBUG LINE
|
||||
return choices(list(weights.keys()), weights=list(weights.values()), k=1)[0]
|
||||
|
||||
def __record_attendance(self, students_present):
|
||||
@ -78,7 +83,7 @@ class ColdCall():
|
||||
# if it's the first one of the day, write it out
|
||||
if not os.path.exists(self.__fn_daily_calllist):
|
||||
with open(self.__fn_daily_calllist, "w") as f:
|
||||
print("\t".join(["discord_name", "timestamp", "answered", "assessment"]), file=f)
|
||||
print("\t".join(["unique_name", "timestamp", "answered", "assessment"]), file=f)
|
||||
|
||||
# open for appending the student
|
||||
with open(self.__fn_daily_calllist, "a") as f:
|
||||
@ -89,7 +94,8 @@ class ColdCall():
|
||||
selected_student = self.__select_student_from_list(students_present)
|
||||
|
||||
# record the called-upon student in the right place
|
||||
self.__record_attendance(students_present)
|
||||
if self.record_attendance:
|
||||
self.__record_attendance(students_present)
|
||||
self.__record_coldcall(selected_student)
|
||||
|
||||
preferred_name = self.__get_preferred_name(selected_student)
|
||||
|
||||
15
coldcallboy-manual.py
Executable file
15
coldcallboy-manual.py
Executable file
@ -0,0 +1,15 @@
|
||||
#!/usr/bin/env python3
|
||||
|
||||
from coldcall import ColdCall
|
||||
import re
|
||||
|
||||
## create the coldcall object
|
||||
cc = ColdCall(record_attendance=False)
|
||||
|
||||
student_list = cc.preferred_names
|
||||
|
||||
# print out 100 students
|
||||
|
||||
for i in range(100):
|
||||
print(f"{i}. {cc.coldcall(student_list)} [ ] [ ]\n")
|
||||
|
||||
4
data/download_data.sh
Executable file
4
data/download_data.sh
Executable file
@ -0,0 +1,4 @@
|
||||
#!/bin/bash
|
||||
|
||||
wget 'https://docs.google.com/spreadsheets/d/FIXME/export?gid=FIXME&format=tsv' -O 'student_information.tsv'
|
||||
|
||||
Loading…
Reference in New Issue
Block a user