{ "cells": [ { "cell_type": "code", "execution_count": 3, "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "开始编译教师版本pdf文件: 临时文件/批量生成题目/递推数列/K0406001X_教师用_20221103.tex\n", "0\n", "开始编译学生版本pdf文件: 临时文件/批量生成题目/递推数列/K0406001X_学生用_20221103.tex\n", "0\n", "开始编译教师版本pdf文件: 临时文件/批量生成题目/递推数列/K0406002X_教师用_20221103.tex\n", "0\n", "开始编译学生版本pdf文件: 临时文件/批量生成题目/递推数列/K0406002X_学生用_20221103.tex\n", "0\n", "开始编译教师版本pdf文件: 临时文件/批量生成题目/递推数列/K0406003X_教师用_20221103.tex\n", "0\n", "开始编译学生版本pdf文件: 临时文件/批量生成题目/递推数列/K0406003X_学生用_20221103.tex\n", "0\n", "开始编译教师版本pdf文件: 临时文件/批量生成题目/递推数列/K0406004X_教师用_20221103.tex\n", "0\n", "开始编译学生版本pdf文件: 临时文件/批量生成题目/递推数列/K0406004X_学生用_20221103.tex\n", "0\n", "开始编译教师版本pdf文件: 临时文件/批量生成题目/递推数列/K0406005X_教师用_20221103.tex\n", "0\n", "开始编译学生版本pdf文件: 临时文件/批量生成题目/递推数列/K0406005X_学生用_20221103.tex\n", "0\n", "开始编译教师版本pdf文件: 临时文件/批量生成题目/递推数列/K0407001X_教师用_20221103.tex\n", "0\n", "开始编译学生版本pdf文件: 临时文件/批量生成题目/递推数列/K0407001X_学生用_20221103.tex\n", "0\n", "开始编译教师版本pdf文件: 临时文件/批量生成题目/递推数列/K0407002X_教师用_20221103.tex\n", "0\n", "开始编译学生版本pdf文件: 临时文件/批量生成题目/递推数列/K0407002X_学生用_20221103.tex\n", "0\n", "开始编译教师版本pdf文件: 临时文件/批量生成题目/递推数列/K0407003X_教师用_20221103.tex\n", "0\n", "开始编译学生版本pdf文件: 临时文件/批量生成题目/递推数列/K0407003X_学生用_20221103.tex\n", "0\n", "开始编译教师版本pdf文件: 临时文件/批量生成题目/递推数列/K0407004X_教师用_20221103.tex\n", "0\n", "开始编译学生版本pdf文件: 临时文件/批量生成题目/递推数列/K0407004X_学生用_20221103.tex\n", "0\n", "开始编译教师版本pdf文件: 临时文件/批量生成题目/递推数列/K0408002X_教师用_20221103.tex\n", "0\n", "开始编译学生版本pdf文件: 临时文件/批量生成题目/递推数列/K0408002X_学生用_20221103.tex\n", "0\n", "开始编译教师版本pdf文件: 临时文件/批量生成题目/递推数列/K0408003X_教师用_20221103.tex\n", "0\n", "开始编译学生版本pdf文件: 临时文件/批量生成题目/递推数列/K0408003X_学生用_20221103.tex\n", "0\n", "开始编译教师版本pdf文件: 临时文件/批量生成题目/递推数列/K0409001X_教师用_20221103.tex\n", "0\n", "开始编译学生版本pdf文件: 临时文件/批量生成题目/递推数列/K0409001X_学生用_20221103.tex\n", "0\n", "开始编译教师版本pdf文件: 临时文件/批量生成题目/递推数列/K0409002X_教师用_20221103.tex\n", "0\n", "开始编译学生版本pdf文件: 临时文件/批量生成题目/递推数列/K0409002X_学生用_20221103.tex\n", "0\n" ] } ], "source": [ "import os,re,time,json,sys\n", "\n", "\"\"\"\n", "模板文件目录下 题目清单.tex 文件不能缺失\n", "\"\"\"\n", "\n", "\"\"\"---设置题目列表---\"\"\"\n", "#字典字段为文件名, 之后为内容的题号\n", "problems_dict = {\n", "\"K0406001X\":\"001739,001740\",\n", "\"K0406002X\":\"010770,010771\",\n", "\"K0406003X\":\"000514,001741,001742,001743,001744,003202,008400,008401,008402,008406,008408,009890\",\n", "\"K0406004X\":\"000403,003211,003219,003630,010778\",\n", "\"K0406005X\":\"000575,003210,003215,003218,003226,009892,010772,010773,010777\",\n", "\"K0407001X\":\"001821\",\n", "\"K0407002X\":\"000307,000320,000574,000950,001795,001803,001813,001818,001823,001824,001825,003205,003206,003213,003214,003273,003309,003310,003319,004179,006968,006969,006974,006982,006983,008404,008405,008407,008409,009894,009895,010774,010775,010779,010780\",\n", "\"K0407003X\":\"001804,001805,001806,001807,001810,001811,001814,001815,001816,001819,001820,001822,003312,003322,006973\",\n", "\"K0407004X\":\"001809,003600,010776\",\n", "\"K0408002X\":\"006910,006912\",\n", "\"K0408003X\":\"000315,000322,001018,001019,001020,001021,001022,001023,001024,001025,003274,003275,003276,003277,003278,003282,003284,003285,003286,003287,003289,004981,006909,006911,006913,006915,006916,006917,006918,006919,006920,006921,006922,006923,006924,006925,006926,006927,006928,006929,006930,006931,006932,006933,006934,006935,006936,006937,006938,006939,006940,006941,006942,006943,006944,006945,006946,006947,006948,006949,006950,006951,006952,006953,006956,006988,006989,006990,008457,008458,008459,008461,008462,008463,008464,008465,008466,008467,008468,008469,008534,009896,009897,009898,010782,010783,010784,010785,010786,010787\",\n", "\"K0409001X\":\"000316,000324,000595,001026,001027,001028,001467,001817,003279,003280,003283,003288,006914,006954,006955,006957,006958,006959,006960,008460,008470,008471,008472,008473,008522,008523,008524,008525,008535,009899,009900,010788\",\n", "\"K0409002X\":\"000323,003281,008474,008475,009901\"\n", "}\n", "\n", "\"\"\"---设置题目列表结束---\"\"\"\n", "\n", "\"\"\"---设置文件保存路径---\"\"\"\n", "#目录和文件的分隔务必用/\n", "directory = \"临时文件/批量生成题目/递推数列/\"\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", "for filename in problems_dict:\n", " problems = problems_dict[filename]\n", " teachers_latex_file = directory + filename + \"_教师用\" + time_string + \".tex\"\n", " students_latex_file = directory + filename + \"_学生用\" + time_string + \".tex\"\n", "\n", " #生成题目列表\n", " problem_list = [id for id in generate_number_set(problems.strip(),pro_dict) if id in pro_dict]\n", "\n", " data_teachers = \"\"\n", " data_students = \"\"\n", " id_list = \"\"\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", " students_string = raw_string + space + \"\\n\\n\"\n", " data_teachers += teachers_string\n", " data_students += students_string\n", "\n", "\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]*windows\",\"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 }