Contar desvios em dois intervalos de células

Contar desvios em dois intervalos de células

Aqui está o que estou tentando fazer:

Correct answers: A C A B D B ...

Student:         Answers:            Score:
--------         --------            ------
Charlie A.       A D A B D C ...     4/6
George B.        A C A B D D ...     5/6

Como você conta as respostas certas comparando as respostas de cada aluno com as respostas da primeira linha? Quero poder calcular a pontuação dos testes inserindo as respostas.

Responder1

Aqui está um script de shell que apenas imprime o número dos mesmos caracteres sem fazer qualquer formatação:

#!/bin/bash

solutions="ACABDB"
input="Charlie A.,ADABDC
George B.,ACABDD"
IFS=$'\n'
for line in $input; do
  name=${line%,*}
  answers=${line#*,}
  correct=0
  for i in $(seq ${#solutions}); do
    [ ${answers:$i:1} == ${solutions:$i:1} ] && ((correct++))
  done
  echo "$line,$correct"
done

E uma versão Ruby que formata os resultados como uma tabela monoespaçada:

solutions = "ACABDB"
"Charlie A.,ADABDC
George B.,ACABDD".split("\n").each { |line|
  name, answer = line.split(",")
  correct = 0
  (0...solutions.length).each { |i|
    correct += 1 if answer[i] == solutions[i]
  }
  puts "#{"%-17s" % name}#{"%-20s" % answer.split("").join(" ")}#{correct}/#{solutions.length}"
}

Você pode salvar os scripts com TextEdit (em modo de texto simples) e depois executá-los no Terminal com algo como bash ~/Desktop/script.shou ruby ~/Desktop/script.rb.

informação relacionada