Подсчет отклонений в двух диапазонах ячеек

Подсчет отклонений в двух диапазонах ячеек

Вот что я пытаюсь сделать:

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

Как вы подсчитываете правильные ответы, сравнивая ответы каждого ученика с ответами в первой строке? Я хочу иметь возможность вычислять баллы тестов, вводя ответы.

решение1

Вот скрипт оболочки, который просто выводит количество одинаковых символов без какого-либо форматирования:

#!/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

И версия на Ruby, которая форматирует результаты в виде моноширинной таблицы:

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}"
}

Вы можете сохранить скрипты с помощью TextEdit (в текстовом режиме), а затем запустить их из Терминала с помощью чего-то вроде bash ~/Desktop/script.shили ruby ~/Desktop/script.rb.

Связанный контент