From ead9a8ac6d99b3cd79223e995cb952eb3c477d19 Mon Sep 17 00:00:00 2001
From: Martin
Napaka:
--[%=message%] -''', - - 'general': '''\ -
Pri razumevanju napake sta pomembni dve vrstici. V predzadnji vrstici je -napisana lokacija napake (line ...), v zadnji vrstici pa izvemo za kakšno -napako gre.
''', - - 'name_error' : '''\ -Napaka NameError
pomeni, da uporabljate nedefinirano vrednost:
-ali vrednost spremenljivke ni določena ali uporabljate funkcijo, ki ni
-uvožena.
TypeError napaka pomeni, da želite izvesti operacijo na nedovoljenih tipih. -Npr., če želite sešteti niz in število ali klicati funkcijo, čeprav tisto ni -funkcija, itd.
''', -} - -hint = { - 'plan': '''\ -Program izvedemo v treh korakih:
-Uporabnika lahko nekaj vprašamo s funkcijo input
. Funkcija
+no_input_call = ['''\
+
Uporabnika lahko nekaj vprašamo s funkcijo input
.
Funkcija
input
sprejme kot argument niz (angl. string), ki se
prikaže uporabniku kot vprašanje in vrne niz, ki ga je uporabnik napisal. Nize
zapisujemo v narekovaje (lahko so enojni ali dvojni). Npr., naslednja
@@ -51,58 +23,89 @@ vrstica:
pokliče funkcijo input
, ki povpraša uporabnika po imenu in si
-shrani uporabnikov odgovor v spremenljivko ime
.
ime
.''']
- 'expressions_python': '''\
-Računanje: če v Pythonu napišemo izraz, se bo ta izračunal. Npr., če -napišemo
+expressions_python = ['''\ +Če v Pythonu napišemo izraz, se bo ta izračunal.
''', + '''\ +Če napišemo
-3 + 6 +3 + 6 * 5-
bo Python seštel vrednosti 3 in 6 in ... rezultat pozabil. Kadar pa želimo -rezultat shraniti, za to uporabimo prireditveni stavek, kjer na levo +
bo Python izračunal 3 + 6 * 5
.
Kadar želimo rezultat shraniti, za to uporabimo prireditveni stavek, kjer na levo napišemo ime spremenljivke, na desno pa izraz:
c = 2 * a * (3 + b)-
Kot vidite, izraz lahko uporablja tudi spremenljivke.
''', +'''] - 'printing': '''\ -V Pythonu izpisujemo s funkcijo print
. Če želimo izpisati več
-elementov, jih ločimo z vejico. Recimo, da imamo spremenljivko
-ime
, ki vsebuje naše ime, potem lahko napišemo:
+printing = ['''\
+
V Pythonu izpisujemo s funkcijo print
.
ime
, ki vsebuje naše ime, potem:
print("Ime mi je", ime, ".") -''', +'''] + +plan = ['''\ +
Program izvedemo v treh korakih:
+Program izvedemo v treh korakih:
+Verjetno uporabljate spremenljivko, ki nima vrednosti. Ali v izrazu za -izračun uporabljate napačno spremenljivko? Ali pri izpisu morda poskušate +
Verjetno uporabljaš spremenljivko, ki nima vrednosti. Ali v izrazu za +izračun uporabljaš napačno spremenljivko? Ali pri izpisu morda poskušaš izpisati napačno spremenljivko?
''' ], 'unsupported_operand' : [ - general_exception['error_head'], - general_exception['general'], - general_exception['type_error'], + mod.general_msg['error_head'], + mod.general_msg['general_exception'], + mod.general_msg['type_error'], '''\Verjetni razlog: funkcija input
vrača vrednost tipa niz, ki jo
moramo najprej pretvoriti v tip float
, če želimo z njo
računati:
v = float(input(" ... --
Zakaj je tako, boste razumeli kasneje, zaenkrat je dovolj, da to poznate.
+''', + '''\Na primeru pretvarjanja temperatur:
fniz = input("Temperatura [F]: ") f = float(fniz) --
ali krajše, združeno v eno vrstico:
+''', + '''\ +Krajše, združeno v eno vrstico:
f = float(input("Temperatura [F]: "))@@ -111,16 +114,17 @@ npr. "10". Če imamo v nizu tudi kakšno črko, bo Python javil napako.''' ], 'not_callable' : [ - general_exception['error_head'], - general_exception['general'], - general_exception['type_error'], + mod.general_msg['error_head'], + mod.general_msg['general_exception'], + mod.general_msg['type_error'], + '''\ +
V programu poskušaš uporabiti število kot funkcijo, a to ne gre.
''', '''\ -V programu poskušate uporabiti število kot funkcijo, a to ne gre. -Verjetni razlog: Ali ste v izrazu pozabili na znak *. Pri pretvorbi temperatur bi namesto:
+Verjetni razlog: Ali si v izrazu pozabil na znak *? Pri pretvorbi temperatur bi namesto:
C = 5/9(F – 32)-
morali napisati:
+moral napisati:
C = 5/9 * (F – 32).diff --git a/python/problems/introduction/pythagorean_theorem/common.py b/python/problems/introduction/pythagorean_theorem/common.py index 405a39c..193527e 100644 --- a/python/problems/introduction/pythagorean_theorem/common.py +++ b/python/problems/introduction/pythagorean_theorem/common.py @@ -1,6 +1,7 @@ # coding=utf-8 -from python.util import has_token_sequence, string_almost_equal +from python.util import has_token_sequence, string_almost_equal, \ + string_contains_number, get_tokens, get_numbers, get_exception_desc from server.hints import Hint, HintSequence id = 188 @@ -52,47 +53,50 @@ def test(python, code): outputs = [ans[1] for ans in answers] n_correct = 0 - for output, correct in zip(outputs, test_out): + tin = None + for i, (output, correct) in enumerate(zip(outputs, test_out)): if string_almost_equal(output, float(correct)): n_correct += 1 + else: + tin = test_in[i][1] + tout = correct passed = n_correct == len(test_in) hints = [{'id': 'test_results', 'args': {'passed': n_correct, 'total': len(test_in)}}] + if tin: + hints.append({'id': 'problematic_test_case', 'args': {'testin': str(tin), 'testout': str(tout)}}) return passed, hints def hint(python, code): + tokens = get_tokens(code) + # run one test first to see if there are any exceptions test_in = [(None, '3\n4\n')] answer = python(code=code, inputs=test_in, timeout=1.0) exc = answer[0][3] - # if have an exception! + exc_hint = get_exception_desc(answer[0][3]) if exc: if 'NameError' in exc: return [{'id':'name_error', 'args': {'message': exc}}] - if 'unsupported operand' in exc or 'TypeError' in exc: + elif 'unsupported operand' in exc or 'TypeError' in exc: return [{'id':'unsupported_operand', 'args': {'message': exc}}] - - # show plan if student is lost - if len(code.strip()) < 5 or (not has_token_sequence(code, ['input']) and - (has_token_sequence(code, ['pi']) or - has_token_sequence(code, ['sin']) or - has_token_sequence(code, ['print']))): - return [{'id': 'plan'}] - + else: + return exc_hint # if input is not present in code, student needs to learn about input - if not has_token_sequence(code, ['input']) or \ - not has_token_sequence(code, ['float']): + if not has_token_sequence(tokens, ['input']) or \ + not has_token_sequence(tokens, ['float']) or \ + not has_token_sequence(tokens, ['=']): return [{'id': 'no_input_call'}] # if tokens sqrt or ** are not in code, we have to teach them how to # use math functions. - if (not has_token_sequence(code, ['sqrt']) or - not has_token_sequence(code, ['**'])): + if (not has_token_sequence(tokens, ['sqrt']) or + not has_token_sequence(tokens, ['**'])): return [{'id' : 'math_functions'}] # student is not using print function - if not has_token_sequence(code, ['print']): + if not has_token_sequence(tokens, ['print']): return [{'id' : 'printing'}] return None diff --git a/python/problems/introduction/pythagorean_theorem/sl.py b/python/problems/introduction/pythagorean_theorem/sl.py index 15c498a..7f26e00 100644 --- a/python/problems/introduction/pythagorean_theorem/sl.py +++ b/python/problems/introduction/pythagorean_theorem/sl.py @@ -1,94 +1,90 @@ # coding=utf-8 +import server +mod = server.problems.load_language('python', 'sl') id = 188 name = 'Pitagorov izrek' slug = 'Pitagorov izrek' description = '''\ -
Npiši program, ki uporabnika vpraša po dolžinah katet pravokotnega trikotnika in +
Napiši program, ki uporabnika vpraša po dolžinah katet pravokotnega trikotnika in izpiše dolžino hipotenuze. ''' -general_exception = { - 'error_head' : '''\ -
Napaka:
--[%=message%] --''', - - 'general': ''' -
Pri razumevanju napake sta pomembni dve vrstici. V predzadnji vrstici je napisana lokacija - napake (line ...), v zadnji vrstici pa izvemo za kakšno napako gre.
- ''', - - 'name_error' : ''' -Napaka NameError
pomeni, da uporabljate nedefinirano vrednost:
- ali vrednost spremenljivke ni določena ali uporabljate funkcijo, ki ni uvožena.
TypeError napaka pomeni, da želite izvesti operacijo na nedovoljenih tipih. - Npr., če želite sešteti niz in število ali klicati funkcijo, čeprav tisto ni funkcija, itd. .
- ''' -} - -hint = { - 'plan': '''\ -Program razdelimo na tri dele kot pri Fahrenheitih:
-Tako kot pri prejšnji nalogi uporabimo funkcijo input, le da tokrat preberemo -dve vrednosti in jih shranimo v dve spremenljivki:
+no_input_call = ['''\ +Tako kot pri prejšnji nalogi za branje uporabimo funkcijo input
Preberemo dve vrednosti in jih shranimo v dve spremenljivki:
a = float(input("Prva kateta: ")) b = float(input("Druga kateta: ")) --
Imeni a
in b
sta spremenljivki (angl. variable).
-Spremenljivke uporabljamo, kadar želimo kakšno vrednost shraniti, ki jo bomo
+''',
+ '''\
+
Imeni a
in b
sta spremenljivki (angl. variable).
+Spremenljivke uporabljamo, kadar želimo kakšno vrednost shraniti, ki jo bomo
potrebovali kasneje v programu. Imena spremenljivk so lahko poljubno
dolga, v našem primeru bi jim lahko rekli tudi kateta_a
in kateta_b
.
- Pri programiranju velja, da izbiramo taka imena spremenljivk,
+ Pri programiranju velja, da izbiramo taka imena spremenljivk,
ki bodo naredila program berljiv.
Dolžina hipotenuze je kvadratni koren vsote kvadratov katet oz.
-c = sqrt(a**2 + b**2)
-Dvojni znak za množenje ** je potenciranje. Funkcija sqrt
-izračuna kvadratni koren. Vendar pa funkcija sqrt
ni vgrajena v Python,
-temveč se nahaja v ločenem matematičnem modulu oz. zbirki matematičnih funkcij.
+math_functions = ['''\
+
Dolžina hipotenuze je kvadratni koren vsote kvadratov katet.
''', + '''\ ++c = sqrt(a**2 + b**2) ++
Dvojni znak za množenje ** je potenciranje. Funkcija sqrt
+izračuna kvadratni koren. ''',
+ '''\
+Funkcija sqrt
ni vgrajena v Python,
+temveč se nahaja v ločenem matematičnem modulu oz. zbirki matematičnih funkcij.
Da bi lahko dostopali do teh funkcij, moramo ta modul najprej uvoziti:
from math import *-
Poleg funkcije sqrt
matematični modul vsebuje še vrsto
-uporabnih matematičnih funkcij, kot so: log, exp, trigonometrične funkcije, itd.
+
Poleg funkcije sqrt
matematični modul vsebuje še vrsto
+uporabnih matematičnih funkcij, kot so: log, exp, trigonometrične funkcije, itd.
Opis modula najdete v Pythonovi dokumentaciji.
V Pythonu izpisujemo s funkcijo V Pythonu izpisujemo s funkcijo Če želimo izpisati več elementov,
+jih ločimo z vejico. Recimo, da imamo spremenljivko Program razdelimo na tri dele kot pri Fahrenheitih: Verjetno uporabljate spremenljivko, ki nima vrednosti. Ali v izrazu za izračun
uporabljate napačno spremenljivko? Ali pri izpisu morda poskušate
izpisati napačno spremenljivko? Verjetni razlog: funkcija print. Če želimo izpisati več elementov,
-jih ločimo z vejico. Recimo, da imamo spremenljivko
ime
,
-ki vsebuje naše ime, potem lahko napišemo:
+printing = ['''\
+print
. ime
,
+ki vsebuje naše ime, potem lahko napišemo:
print("Ime mi je", ime, ".")
'''],
- 'name_error' : [general_exception['error_head'], general_exception['general'],
- general_exception['name_error'], '''
+plan = ['''\
+
+
+''',
+ no_input_call,
+ math_functions,
+ printing]
+
+hint = {
+ 'no_input_call': no_input_call,
+
+ 'math_functions': math_functions,
+
+ 'printing': printing,
+
+ 'name_error' : [mod.general_msg['error_head'], mod.general_msg['general_exception'],
+ mod.general_msg['name_error'], '''
input
vrača vrednost tipa niz,
ki jo moramo najprej pretvoriti v tip float
, če želimo z njo računati:
--
cgit v1.2.1