problems = ["1:500"] #题号列表, 每个字符串表示一个分块的题目 notetitle = "测试讲义教师版" #讲义标题, 也是文件标题 sectiontitles = ["课前","课后"] #小节标题列表, 如果与题号列表长度不符则作为不设小节处理 consecutivenumbering = False #不同小节是否连续编号, True表示连续编号, False表示每小节从1开始编号 topandbottomusagestuple = (2,0) #表示保留得分率最高的使用记录与最低的使用记录的个数, 有负数表示不排列 from database_tools import * prodictpath = "../题库0.3/problems.json" objdictpath = "../题库0.3/lessonobj.json" pro_dict = load_dict(prodictpath) obj_dict = load_dict(objdictpath) outputdir = "临时文件" #输出文件的目录 outputfilepath = os.path.join(outputdir,notetitle+".tex") print("输出文件目录: %s\n输出文件名: %s"%(os.path.join(os.getcwd(),outputdir),notetitle+".tex")) latex_raw = ReadTextFile("模板文件/讲义模板.txt") latex_raw = latex_raw.replace(r"学号\blank{50} \ 姓名\blank{80}","上海市控江中学") if sys.platform != "win32": #非win系统用默认字体 latex_raw = re.sub(r"fontset[\s]*=[\s]*none","fontset = fandol",latex_raw) latex_raw = re.sub(r"\\setCJKmainfont",r"% \\setCJKmainfont",latex_raw) bodystring = GenerateTeacherBodyString(problems,sectiontitles,pro_dict,obj_dict,consecutivenumbering,topandbottomusagestuple) #生成.tex中的内容主体字符串, 用于替换模板中的相应部分 latex_data = StringSubstitute(r"<<[\s\S]*?待替换[\s\S]*?>>",latex_raw,(notetitle,bodystring)) #替换标题和bodystring SaveTextFile(latex_data,outputfilepath) #保存.tex文件 if XeLaTeXCompile(outputdir,notetitle+".tex"): print("编译成功") else: print("编译失败")