-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathClass_Creator.py
More file actions
120 lines (106 loc) · 7.04 KB
/
Class_Creator.py
File metadata and controls
120 lines (106 loc) · 7.04 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
from Class_Gener import *
from fpdf import FPDF
class Creator:
def export_task(self, path, key):
pdf = FPDF()
pdf.add_page()
pdf.add_font('Arial', '', './Arial.ttf', uni=True)
pdf.set_font('Arial', '', 14)
res = self.function_creator(key)
pdf.multi_cell(190, 10, txt=res[0])
pdf.output(path)
return res
def export_PDF(self, path, text):
pdf = FPDF()
pdf.add_page()
pdf.add_font('Arial', '', './Arial.ttf', uni=True)
pdf.set_font('Arial', '', 14)
pdf.multi_cell(190, 10, txt=text)
pdf.output(path)
def function_creator(self, key):
que_text_result = ""
ans_text_result = ""
if key["Type"].lower() == "однотипные задания":
if key["Subject"].lower() == "физика":
if key["Theme"].lower() == "кинематика":
if key["Theme_section"].lower() == "равномерное движение":
for i in range(int(key["N"])):
que_ans_text = TaskGenerator().uniform_motion()
ans_text_result += f'{i + 1}) Ответ: '
for j, answer in enumerate(que_ans_text[1]):
ans_text_result += f'<tg-spoiler>{answer} {que_ans_text[2][j]}</tg-spoiler>'
que_text_result += f'{i+1}) {que_ans_text[0]}\n\n'
ans_text_result += '\n'
return que_text_result, ans_text_result
elif key["Theme_section"].lower() == "равноускоренное движение":
for i in range(int(key["N"])):
que_ans_text = TaskGenerator().equiaxed_motion()
ans_text_result += f'{i + 1}) Ответ: '
for j, answer in enumerate(que_ans_text[1]):
ans_text_result += f'<tg-spoiler>{answer} {que_ans_text[2][j]}</tg-spoiler>'
que_text_result += f'{i+1}) {que_ans_text[0]}\n\n'
ans_text_result += '\n'
return que_text_result, ans_text_result
elif key["Theme"].lower() == "баллистика":
if key["Theme_section"].lower() == "свободное падение тел":
for i in range(int(key["N"])):
que_ans_text = TaskGenerator().ballistics_motion()
ans_text_result += f'{i + 1}) Ответ: '
for j, answer in enumerate(que_ans_text[1]):
ans_text_result += f'<tg-spoiler>{answer} {que_ans_text[2][j]}</tg-spoiler>'
que_text_result += f'{i+1}) {que_ans_text[0]}\n\n'
ans_text_result += '\n'
return que_text_result, ans_text_result
elif key["Theme_section"].lower() == "баллистическое движение":
for i in range(int(key["N"])):
que_ans_text = TaskGenerator().ballistics_corner_motion()
ans_text_result += f'{i + 1}) Ответ: '
for j, answer in enumerate(que_ans_text[1]):
ans_text_result += f'<tg-spoiler>{answer} {que_ans_text[2][j]}</tg-spoiler>'
que_text_result += f'{i+1}) {que_ans_text[0]}\n\n'
ans_text_result += '\n'
return que_text_result, ans_text_result
elif key["Type"] == "контрольная работа":
if key["Subject"] == "физика":
if key["Theme"] == "кинематика":
if key["Theme_section"] == "":
num_questions = round(0.3 * int(key["N"]))
num_tests = round(0.2 * int(key["N"]))
num_problems = int(key["N"]) - num_questions - num_tests
for i in range(num_questions):
que_text_result += f'{i+1}) {TaskGenerator().questions_for_kr_kinematics()}\n\n'
for i in range(num_tests):
que_text_result += f'{num_questions + i+1}) {TaskGenerator().tests_for_kr_kinematics()}\n\n'
for i in range(num_problems):
que_ans_text = TaskGenerator().phis_kr_kinematics()
que_text_result += f'{num_questions+num_tests+i+1}) {que_ans_text[0]}\n\n'
ans_text_result += f'{num_questions+num_tests+i+1}) Ответ: <tg-spoiler>{que_ans_text[1][0]} {que_ans_text[2][0]}</tg-spoiler>\n'
return que_text_result, ans_text_result
elif key["Theme"] == "механика":
if key["Theme_section"] == "":
num_questions = round(0.3 * int(key["N"]))
num_tests = round(0.2 * int(key["N"]))
num_problems = int(key["N"]) - num_questions - num_tests
for i in range(num_questions):
que_text_result += f'{i+1}) {TaskGenerator().questions_for_kr_mechanics()}\n\n'
for i in range(num_tests):
que_text_result += f'{num_questions + i+1}) {TaskGenerator().tests_for_kr_mechanics()}\n\n'
for i in range(num_problems):
que_ans_text = TaskGenerator().phis_kr_mechanics()
que_text_result += f'{num_questions+num_tests+i+1}) {que_ans_text[0]}\n\n'
ans_text_result += f'{num_questions+num_tests+i+1}) Ответ: <tg-spoiler>{que_ans_text[1][0]} {que_ans_text[2][0]}</tg-spoiler>\n'
return que_text_result, ans_text_result
elif key["Theme"] == "баллистика":
if key["Theme_section"] == "":
num_questions = round(0.3 * int(key["N"]))
num_tests = round(0.2 * int(key["N"]))
num_problems = int(key["N"]) - num_questions - num_tests
for i in range(num_questions):
que_text_result += f'{i+1}) {TaskGenerator().questions_for_kr_ballistics()}\n\n'
for i in range(num_tests):
que_text_result += f'{num_questions + i+1}) {TaskGenerator().tests_for_kr_ballistics()}\n\n'
for i in range(num_problems):
que_ans_text = TaskGenerator().phis_kr_ballistics()
que_text_result += f'{num_questions+num_tests+i+1}) {que_ans_text[0]}\n\n'
ans_text_result += f'{num_questions+num_tests+i+1}) Ответ: <tg-spoiler>{que_ans_text[1][0]} {que_ans_text[2][0]}</tg-spoiler>\n'
return que_text_result, ans_text_result