version 1.8, 2001/10/19 22:03:05
|
version 1.23, 2001/12/06 21:57:23
|
Line 11
|
Line 11
|
# 08/30,08/31,09/06,09/14,09/15,09/16,09/19,09/20,09/21,09/23, |
# 08/30,08/31,09/06,09/14,09/15,09/16,09/19,09/20,09/21,09/23, |
# 10/02,10/10,10/14,10/16,10/18,10/19,10/31,11/6,11/14,11/16 Gerd Kortemeyer) |
# 10/02,10/10,10/14,10/16,10/18,10/19,10/31,11/6,11/14,11/16 Gerd Kortemeyer) |
# |
# |
# 3/1/1,6/1,17/1,29/1,30/1 Gerd Kortemeyer) |
# 3/1/1,6/1,17/1,29/1,30/1,31/1 Gerd Kortemeyer) |
# |
|
# 1/31 Gerd Kortemeyer |
|
# |
|
# 7/10/01 Behrouz Minaei |
# 7/10/01 Behrouz Minaei |
# 9/8 Gerd Kortemeyer |
# 9/8 Gerd Kortemeyer |
# 10/18/01, 10/19/01 Behrouz Minaei |
# 10/18/01, 10/19/01 Behrouz Minaei |
|
# 11/17/01, 11/22/01, 11/24/01, 11/28/01 Behrouz Minaei |
|
|
package Apache::lonchart; |
package Apache::lonchart; |
|
|
Line 47 sub ExtractStudentData {
|
Line 45 sub ExtractStudentData {
|
my $Wrongs; |
my $Wrongs; |
my %TempHash; |
my %TempHash; |
my $Version; |
my $Version; |
my $LatestVersion; |
my $ProbNo; |
|
my $PrTotal; |
|
my $LatestVersion; |
my $Str=substr($students[$index]. |
my $Str=substr($students[$index]. |
' ',0,14).' ! '. |
' ',0,14).' ! '. |
substr($rowlabels[$index]. |
substr($rowlabels[$index]. |
' ',0,45).' ! '; |
' ',0,45).' ! '; |
|
|
unless ($reply=~/^error\:/) { |
unless ($reply=~/^error\:/) { |
map { |
map { |
my ($name,$value)=split(/\=/,&Apache::lonnet::unescape($_)); |
my ($name,$value)=split(/\=/,&Apache::lonnet::unescape($_)); |
$result{$name}=$value; |
$result{$name}=$value; |
} split(/\&/,$reply); |
} split(/\&/,$reply); |
|
$ProbNo = 0; |
|
$PrTotal = 0; |
|
my $IterationNo = 0; |
foreach $ResId (@cols) { |
foreach $ResId (@cols) { |
if ( !$ResId ) { $Str .= ' ! '; next; } |
if ($IterationNo == 0) {$IterationNo++; next;} |
|
if (!$ResId) { |
|
my $PrNo = sprintf( "%3d", $ProbNo ); |
|
$Str .= ' '.'<font color="#007700">'.$PrNo.'</font> '; |
|
$PrTotal += $ProbNo; |
|
$ProbNo=0; |
|
next; |
|
} |
$ResId=~/(\d+)\.(\d+)/; |
$ResId=~/(\d+)\.(\d+)/; |
|
my $meta=$hash{'src_'.$ResId}; |
|
my $PartNo = 0; |
|
undef %TempHash; |
|
map { |
|
if ($_=~/^stores\_(\d+)\_tries$/) { |
|
my $Part=&Apache::lonnet::metadata($meta,$_.'.part'); |
|
if ( $TempHash{"$Part"} eq '' ) { |
|
$TempHash{"$Part"} = $Part; |
|
$TempHash{$PartNo}=$Part; |
|
$TempHash{"$Part.Code"} = ' '; |
|
$PartNo++; |
|
} |
|
} |
|
} split(/\,/,&Apache::lonnet::metadata($meta,'keys')); |
|
|
my $Prob = &Apache::lonnet::declutter( $hash{'map_id_'.$1} ). |
my $Prob = &Apache::lonnet::declutter( $hash{'map_id_'.$1} ). |
'___'.$2.'___'. |
'___'.$2.'___'. |
&Apache::lonnet::declutter( $hash{'src_'.$ResId} ); |
&Apache::lonnet::declutter( $hash{'src_'.$ResId} ); |
Line 69 sub ExtractStudentData {
|
Line 92 sub ExtractStudentData {
|
$Tries = 0; |
$Tries = 0; |
$LatestVersion = $result{"version:$Prob"}; |
$LatestVersion = $result{"version:$Prob"}; |
|
|
undef %TempHash; |
|
my $PartNo = 0; |
|
|
|
if ( $LatestVersion ) { |
if ( $LatestVersion ) { |
|
|
for ( my $Version=1; $Version<=$LatestVersion; $Version++ ) { |
for ( my $Version=1; $Version<=$LatestVersion; $Version++ ) { |
my $vkeys = $result{"$Version:keys:$Prob"}; |
my $vkeys = $result{"$Version:keys:$Prob"}; |
my @keys = split(/\:/,$vkeys); |
my @keys = split(/\:/,$vkeys); |
|
|
foreach my $Key (@keys) { |
foreach my $Key (@keys) { |
if (($Key=~/\.(\w+)\.solved$/) && ($Key!~/^\d+\:/)) { |
if (($Key=~/\.(\w+)\.solved$/) && ($Key!~/^\d+\:/)) { |
my $Part = $1; |
my $Part = $1; |
if ( $TempHash{"$Part"} eq '' ) { |
|
$TempHash{"$Part"} = $Part; |
|
$TempHash{$PartNo}=$Part; |
|
$PartNo++; |
|
} |
|
$TempHash{"$Part.Tries"} = $result{"$Version:$Prob:resource.$Part.tries"}; |
|
$Tries = $result{"$Version:$Prob:resource.$Part.tries"}; |
$Tries = $result{"$Version:$Prob:resource.$Part.tries"}; |
my $Val = $result{"$Version:$Prob:$Key"}; |
$TempHash{"$Part.Tries"}=($Tries) ? $Tries : 0; |
|
my $Val = $result{"$Version:$Prob:resource.$Part.solved"}; |
if ($Val eq 'correct_by_student'){$Code='*';} |
if ($Val eq 'correct_by_student'){$Code='*';} |
elsif ($Val eq 'correct_by_override'){$Code = '+';} |
elsif ($Val eq 'correct_by_override'){$Code = '+';} |
elsif ($Val eq 'incorrect_attempted'){$Code = '.';} |
elsif ($Val eq 'incorrect_attempted'){$Code = '.';} |
elsif ($Val eq 'incorrect_by_override'){$Code = '-';} |
elsif ($Val eq 'incorrect_by_override'){$Code = '-';} |
elsif ($Val eq 'excused'){$Code = 'x';} |
elsif ($Val eq 'excused'){$Code = 'x';} |
|
elsif ($Val eq 'ungraded_attempted'){$Code = '#';} |
|
else {$Code = ' ';} |
$TempHash{"$Part.Code"} = $Code; |
$TempHash{"$Part.Code"} = $Code; |
} |
} |
} |
} |
} |
} |
|
|
for ( my $n = 0; $n < $PartNo; $n++ ) { |
for ( my $n = 0; $n < $PartNo; $n++ ) { |
my $part = $TempHash{$n}; |
my $part = $TempHash{$n}; |
if (($TempHash{$part.'.Code'} eq '*')&& |
if ($TempHash{"$part.Code"} eq '*') { |
($TempHash{$part.'.Tries'}<10)) { |
$ProbNo++; |
$TempHash{$part.'.Code'}=$Tries; |
if (($TempHash{"$part.Tries"}<10) || |
|
($TempHash{"$part.Tries"} eq '')) { |
|
$TempHash{"$part.Code"}=$TempHash{"$part.Tries"}; |
|
} |
} |
} |
$Str .= $TempHash{$part.'.Code'}; |
$Str .= $TempHash{"$part.Code"}; |
} |
} |
} |
} |
else { $Str .= ' '; } |
else {for(my $n=0; $n<$PartNo; $n++) {$Str.=' ';}} |
} |
} |
} |
} |
return $Str; |
my $PrTot = sprintf( "%5d", $PrTotal ); |
|
$Str .= ' '.'<font color="#000088">'.$PrTot.'</font> '; |
|
|
|
return $Str ; |
} |
} |
|
|
|
|
Line 207 sub handler {
|
Line 229 sub handler {
|
" +: correct by override\n". |
" +: correct by override\n". |
" -: incorrect by override\n". |
" -: incorrect by override\n". |
" .: incorrect attempted\n". |
" .: incorrect attempted\n". |
|
" #: ungraded attempted\n". |
" : not attempted\n". |
" : not attempted\n". |
" x: excused</pre><p>"); |
" x: excused</pre><p>"); |
|
|