63 lines
2.3 KiB
Python
63 lines
2.3 KiB
Python
outputpath = "临时文件/新题比对.tex"
|
|
|
|
|
|
|
|
from database_tools_2 import *
|
|
colors = ["green","orange","blue"]
|
|
templatepath = "./模板文件/讲义模板.txt"
|
|
|
|
mydb = connect(hostname = db_host, port = db_port, username=db_user, pwd=db_pwd, db = db_database)
|
|
mycursor = mydb.cursor()
|
|
|
|
mycursor.execute("SELECT ID,content FROM problems;")
|
|
ret_list = mycursor.fetchall()
|
|
pro_dict = {i:j for i,j in ret_list}
|
|
treated_dict = {i:pre_treating(pro_dict[i]) for i in pro_dict.keys()}
|
|
mydb.close()
|
|
|
|
data_raw = getCopy()
|
|
if data_raw.strip().startswith("\\item"):
|
|
data_raw = "\\begin{enumerate}\n"+data_raw
|
|
if data_raw.count("\\begin{enumerate}") == data_raw.count("\\end{enumerate}") + 1:
|
|
data_raw = data_raw + "\n\\end{enumerate}"
|
|
problems_raw = re.findall(r"\\begin\{enumerate\}([\s\S]*?)\\end\{enumerate\}",data_raw)
|
|
data = "\n".join([item.strip() for item in problems_raw])
|
|
problems = [(d.strip()) for d in data.split("\\item") if not d.strip() == ""]
|
|
output = "使用说明:\\\\\n rep??????表示使用已有题号??????,\\\\\n s??????表示和??????相同,\\\\\n r??????表示和??????相关\n\n\\begin{enumerate}\n\n"
|
|
|
|
|
|
for p in problems:
|
|
p_treated = pre_treating(p)
|
|
t = stringmaxsim(p_treated,treated_dict,5)
|
|
psrstring = ""
|
|
for id,simrate in t:
|
|
if simrate == 1:
|
|
psrstring = "rep"+id+","
|
|
else:
|
|
psrstring += id + ","
|
|
if psrstring[-1] == ",":
|
|
psrstring = psrstring[:-1]
|
|
output += f"\\item [{psrstring}] {p}\n\n"
|
|
count = 0
|
|
for id,simrate in t:
|
|
if simrate > 0.5:
|
|
colors = get_color(simrate*2-1)
|
|
output += "\n\\definecolor{mycolor}{rgb}"+colors
|
|
output += "\n\\begin{tcolorbox}"+f"[colback = mycolor, opacityback = 0.25, colframe = orange!10!white, breakable]\n"
|
|
output += f"{simrate:.3f} \\ {id}\n\n"
|
|
content = pro_dict[id]
|
|
output += f"{content}\n"
|
|
output += "\\end{tcolorbox}\n"
|
|
count += 1
|
|
output += "\n\n"
|
|
output += "\n\\end{enumerate}\n\n"
|
|
|
|
texraw = ReadTextFile(templatepath)
|
|
texdata = StringSubstitute(r"<<[\s\S]*?待替换[\s\S]*?>>",texraw,("新题比对"+f"{GetDate()}",output))
|
|
|
|
|
|
texfilepath = os.path.join(os.getcwd(),outputpath)
|
|
SaveTextFile(texdata,texfilepath)
|
|
os.system(f"code {texfilepath}")
|
|
# dir,filename = os.path.split(texfilepath)
|
|
# XeLaTeXCompile(dir,filename) |