214 lines
11 KiB
Plaintext
214 lines
11 KiB
Plaintext
{
|
|
"cells": [
|
|
{
|
|
"cell_type": "code",
|
|
"execution_count": 1,
|
|
"metadata": {},
|
|
"outputs": [
|
|
{
|
|
"name": "stdout",
|
|
"output_type": "stream",
|
|
"text": [
|
|
"开始编译教师版本pdf文件: 临时文件/二项式定理预选_教师用_20221129.tex\n",
|
|
"0\n",
|
|
"开始编译学生版本pdf文件: 临时文件/二项式定理预选_学生用_20221129.tex\n",
|
|
"0\n"
|
|
]
|
|
}
|
|
],
|
|
"source": [
|
|
"import os,re,time,json,sys\n",
|
|
"\n",
|
|
"\"\"\"\n",
|
|
"模板文件目录下 题目清单.tex 文件不能缺失\n",
|
|
"\"\"\"\n",
|
|
"\n",
|
|
"\"\"\"---设置题目列表---\"\"\"\n",
|
|
"#字典字段为文件名, 之后为内容的题号\n",
|
|
"problems_dict = {\n",
|
|
"\"K0819002X\":\"000811,002619,003997,004192,007528,007541,007544,007545,007559,007563,007574,007575,007576,007582,007604,007663,007664,010877,010883,011369\",\n",
|
|
"\"K0819004X\":\"000837,002621\",\n",
|
|
"\"K0819005X\":\"000333,000340,000373,000385,000393,000398,000410,000418,000435,000439,000470,000483,000502,000521,000532,000539,000563,000568,000580,000600,000620,000640,000658,000694,000722,000735,000737,000753,000774,000800,000823,000828,000849,000866,000873,000885,000914,000929,000951,002612,002613,002614,002615,002616,002617,002618,002620,002622,002623,002633,003584,003594,003634,003654,003735,003759,003764,003867,004021,004030,004104,004127,004148,004170,004231,004250,004298,004430,004450,004475,004517,004536,004558,004663,004686,004727,004747,007527,007529,007530,007531,007532,007542,007543,007546,007547,007549,007552,007553,007554,007555,007556,007557,007560,007561,007562,007577,007578,007581,007586,007587,007588,007589,007590,007591,007592,007593,007594,007595,007596,007597,007598,007599,007601,007602,007603,007605,007606,007607,007623,007631,007659,007660,007679,009303,009304,009305,009306,009311,009315,009316,009320,009325,009334,009407,009411,009421,009945,010875,010876,010879,010880,010882,010990,011054,011137,011226,011269,011293,011308,011340,011347,011396,011415,011459,011498,011528,011628,011651,011703,011993,012011,030022\",\n",
|
|
"\"K0819006X\":\"002635,002637,004028,007539,007540,007585,007628,007638,007639,007640,007641,007642,007643,007644,007645,009308,009318,009319,009946,009990\",\n",
|
|
"\"K0820001X\":\"002626,002627,002628,002631,002634,002639,003573,003811,003942,003962,003991,004020,004027,004211,007533,007534,007535,007536,007537,007538,007550,007564,007565,007566,007567,007568,007569,007570,007571,007572,007573,007580,007584,007611,007612,007613,007614,007615,007617,007620,007621,007625,007626,007627,007629,007630,007633,007636,007637,007646,007647,007648,007651,007658,007661,007662,007676,007677,007678,009310,009312,009314,009343,009419,009947,011442,030071\",\n",
|
|
"\"K0820002X\":\"000359,003840,004019,004711,007618,007622,009339,009408\",\n",
|
|
"\"K0820003X\":\"002624,002629,002630,002636,003578,003851,003883,004342,004625,004678,007548,007551,007558,007608,009313,009948,010878,010881,012026\",\n",
|
|
"}\n",
|
|
"\n",
|
|
"\"\"\"---设置题目列表结束---\"\"\"\n",
|
|
"\n",
|
|
"\"\"\"---设置文件保存路径---\"\"\"\n",
|
|
"#目录和文件的分隔务必用/\n",
|
|
"directory = \"临时文件/\"\n",
|
|
"filename = \"二项式定理预选\"\n",
|
|
"\"\"\"---设置文件名结束---\"\"\"\n",
|
|
"if directory[-1] != \"/\":\n",
|
|
" directory += \"/\"\n",
|
|
"\n",
|
|
"\n",
|
|
"#生成数码列表, 逗号分隔每个区块, 区块内部用:表示整数闭区间\n",
|
|
"def generate_number_set(string,dict):\n",
|
|
" string = re.sub(r\"[\\n\\s]\",\"\",string)\n",
|
|
" string_list = string.split(\",\")\n",
|
|
" numbers_list = []\n",
|
|
" for s in string_list:\n",
|
|
" if not \":\" in s:\n",
|
|
" numbers_list.append(s.zfill(6))\n",
|
|
" else:\n",
|
|
" start,end = s.split(\":\")\n",
|
|
" for ind in range(int(start),int(end)+1):\n",
|
|
" numbers_list.append(str(ind).zfill(6))\n",
|
|
" return numbers_list\n",
|
|
"\n",
|
|
"#将正确率转化为含颜色代码的字符串\n",
|
|
"def get_color(value):\n",
|
|
" value = float(value)\n",
|
|
" if value>=0.5:\n",
|
|
" (r,g,b)=(1,2-2*value,0)\n",
|
|
" else:\n",
|
|
" (r,g,b)=(2*value,1,0)\n",
|
|
" return \"{\" + \"%.3f\" %(r) + \",\" + \"%.3f\" %(g) + \",0}\"\n",
|
|
"\n",
|
|
"\n",
|
|
"def color_value(matchobj):\n",
|
|
" value = matchobj.group(1)\n",
|
|
" return \"\\t\"+\"\\\\fcolorbox[rgb]{0,0,0}\"+ get_color(value) +\"{\" + value +\"}\"\n",
|
|
"\n",
|
|
"\n",
|
|
"#读取题库json文件并转化为字典\n",
|
|
"with open(r\"../题库0.3/Problems.json\",\"r\",encoding = \"utf8\") as f:\n",
|
|
" database = f.read()\n",
|
|
"pro_dict = json.loads(database)\n",
|
|
"\n",
|
|
"#读取目标数据库json并转化为字典\n",
|
|
"with open(r\"../题库0.3/LessonObj.json\",\"r\",encoding = \"utf8\") as f:\n",
|
|
" database = f.read()\n",
|
|
"obj_dict = json.loads(database)\n",
|
|
"\n",
|
|
"try:\n",
|
|
" os.mkdir(directory)\n",
|
|
"except:\n",
|
|
" pass\n",
|
|
"\n",
|
|
"#读取系统日期\n",
|
|
"current_time = time.localtime()\n",
|
|
"time_string = \"_\"+str(current_time.tm_year).zfill(4)+str(current_time.tm_mon).zfill(2)+str(current_time.tm_mday).zfill(2)\n",
|
|
"\n",
|
|
"\n",
|
|
"data_teachers = \"\"\n",
|
|
"data_students = \"\"\n",
|
|
"\n",
|
|
"teachers_latex_file = directory + filename + \"_教师用\" + time_string + \".tex\"\n",
|
|
"students_latex_file = directory + filename + \"_学生用\" + time_string + \".tex\"\n",
|
|
"\n",
|
|
"for section_name in problems_dict:\n",
|
|
" problems = problems_dict[section_name]\n",
|
|
"\n",
|
|
" data_teachers += r\"\\newpage\" + \"\\n\\n\" + r\"\\section{\" + section_name +\"}\\n\\n\"\n",
|
|
" data_students += r\"\\newpage\" + \"\\n\\n\" + r\"\\section{\" + section_name +\"}\\n\\n\"\n",
|
|
"\n",
|
|
" #生成题目列表\n",
|
|
" problem_list = [id for id in generate_number_set(problems.strip(),pro_dict) if id in pro_dict]\n",
|
|
"\n",
|
|
"\n",
|
|
"\n",
|
|
"\n",
|
|
" #生成教师题目字符串与学生题目字符串, 准备替换至latex文件\n",
|
|
" for id in problem_list:\n",
|
|
" problemset = pro_dict[id]\n",
|
|
" problem = problemset[\"content\"]\n",
|
|
" solution = (problemset[\"solution\"] if problemset[\"solution\"] != \"\" else \"暂无解答与提示\")\n",
|
|
" answer = \"\\\\textcolor{red}{\" + (problemset[\"ans\"] if problemset[\"ans\"] != \"\" else \"暂无答案\") + \"}\"\n",
|
|
" remarks = (problemset[\"remark\"] if problemset[\"remark\"] != \"\" else \"暂无备注\")\n",
|
|
" usages_list = problemset[\"usages\"]\n",
|
|
" if len(usages_list) > 0:\n",
|
|
" usage = re.sub(\"\\\\t([\\d]\\.[\\d]{0,10})\",color_value,\"\\n\\n\".join(usages_list))\n",
|
|
" usage = re.sub(\"[\\\\t ]([\\d]\\.[\\d]{0,10})\",color_value,usage)\n",
|
|
" else:\n",
|
|
" usage = \"暂无使用记录\"\n",
|
|
" origin = (problemset[\"origin\"] if problemset[\"origin\"] != \"\" else \"出处不详\")\n",
|
|
" objects = problemset[\"objs\"]\n",
|
|
" if len(objects) == 0:\n",
|
|
" objects = \"暂未关联目标\\n\\n\"\n",
|
|
" elif \"KNONE\" in [o.upper() for o in objects]:\n",
|
|
" objects = \"该题的考查目标不在目前的集合中\\n\\n\"\n",
|
|
" else:\n",
|
|
" objects_string = \"\"\n",
|
|
" for obj in objects:\n",
|
|
" if not obj in obj_dict:\n",
|
|
" objects_string = \"目标\" + obj + \"有误\\n\\n\"\n",
|
|
" break\n",
|
|
" else:\n",
|
|
" objects_string += \"\\\\textcolor{blue}{\" + obj + \"|\" + obj_dict[obj][\"content\"] + \"}\\n\\n\"\n",
|
|
" objects = objects_string\n",
|
|
" space = (\"\" if problemset[\"space\"] == \"\" else r\"\\vspace*{\"+problemset[\"space\"]+\"}\\n\")\n",
|
|
" tags = (\"|\".join(problemset[\"tags\"]) if len(problemset[\"origin\"])>0 else \"暂无标签\")\n",
|
|
" raw_string = \"\\\\item \" + \"{\\\\tiny (\"+id+\")}\"+problem\n",
|
|
" teachers_string = raw_string.replace(\"\\\\tiny\",\"\")+\"\\n\\n关联目标:\\n\\n\"+ objects + \"\\n\\n标签: \" + tags + \"\\n\\n答案: \"+answer + \"\\n\\n\" + \"解答或提示: \" + solution + \"\\n\\n使用记录:\\n\\n\"+ usage + \"\\n\" + \"\\n\\n出处: \"+origin + \"\\n\\n\"\n",
|
|
" students_string = raw_string + space + \"\\n\\n\"\n",
|
|
" data_teachers += teachers_string\n",
|
|
" data_students += students_string\n",
|
|
"\n",
|
|
"#去除第一个newpage\n",
|
|
"data_teachers = data_teachers[10:]\n",
|
|
"data_students = data_students[10:]\n",
|
|
"\n",
|
|
"#替换latex文件的内容并编译\n",
|
|
"with open(\"模板文件/题目清单.tex\",\"r\",encoding = \"utf8\") as f:\n",
|
|
" latex_raw = f.read()\n",
|
|
"#识别操作系统\n",
|
|
"if sys.platform != \"win32\":\n",
|
|
" latex_raw = re.sub(r\"fontset[\\s]*=[\\s]*none\",\"fontset = fandol\",latex_raw)\n",
|
|
" latex_raw = re.sub(r\"\\\\setCJKmainfont\",r\"% \\\\setCJKmainfont\",latex_raw)\n",
|
|
"latex_teachers = latex_raw.replace(\"编译模板\",data_teachers)\n",
|
|
"with open(teachers_latex_file,\"w\",encoding = \"utf8\") as f:\n",
|
|
" f.write(latex_teachers)\n",
|
|
"print(\"开始编译教师版本pdf文件: \", teachers_latex_file)\n",
|
|
"os.system(\"xelatex -interaction=batchmode -output-directory=\" + directory + \" \"+ teachers_latex_file)\n",
|
|
"print(os.system(\"xelatex -interaction=batchmode -output-directory=\" + directory + \" \"+ teachers_latex_file))\n",
|
|
"\n",
|
|
"latex_students = latex_raw.replace(\"编译模板\",data_students)\n",
|
|
"with open(students_latex_file,\"w\",encoding = \"utf8\") as f:\n",
|
|
" f.write(latex_students)\n",
|
|
"print(\"开始编译学生版本pdf文件: \", students_latex_file)\n",
|
|
"os.system(\"xelatex -interaction=batchmode -output-directory=\" + directory + \" \"+ students_latex_file)\n",
|
|
"print(os.system(\"xelatex -interaction=batchmode -output-directory=\" + directory + \" \"+ students_latex_file))\n"
|
|
]
|
|
},
|
|
{
|
|
"cell_type": "code",
|
|
"execution_count": null,
|
|
"metadata": {},
|
|
"outputs": [],
|
|
"source": []
|
|
}
|
|
],
|
|
"metadata": {
|
|
"kernelspec": {
|
|
"display_name": "Python 3.8.8 ('base')",
|
|
"language": "python",
|
|
"name": "python3"
|
|
},
|
|
"language_info": {
|
|
"codemirror_mode": {
|
|
"name": "ipython",
|
|
"version": 3
|
|
},
|
|
"file_extension": ".py",
|
|
"mimetype": "text/x-python",
|
|
"name": "python",
|
|
"nbconvert_exporter": "python",
|
|
"pygments_lexer": "ipython3",
|
|
"version": "3.8.8"
|
|
},
|
|
"orig_nbformat": 4,
|
|
"vscode": {
|
|
"interpreter": {
|
|
"hash": "d311ffef239beb3b8f3764271728f3972d7b090c974f8e972fcdeedf230299ac"
|
|
}
|
|
}
|
|
},
|
|
"nbformat": 4,
|
|
"nbformat_minor": 2
|
|
}
|