40 lines
1.7 KiB
Python
40 lines
1.7 KiB
Python
problems = ["1:50000"] #题号列表, 每个字符串表示一个分块的题目
|
|
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")
|
|
|
|
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("编译失败")
|
|
|
|
|
|
|