36 lines
1.6 KiB
Python
36 lines
1.6 KiB
Python
from apps.project.models import Problem
|
||
from utils.util import get_str_dict
|
||
from apps.createDocument.extensions.parse_rich_text import RichParser
|
||
|
||
def parse_html(html_txt, a_list, doc):
|
||
"""解析HTML字段的文字和图片到列表,输入是HTML字段的txt以及列表,输出列表"""
|
||
parser = RichParser(html_txt)
|
||
a_list.extend(parser.get_final_list(doc, img_size=80))
|
||
return a_list
|
||
|
||
def create_one_problem_dit(problem: Problem, problem_prefix: str, doc) -> dict:
|
||
"""问题单汇总表每个问题作为一行的数据"""
|
||
problem_dict = {
|
||
'ident': '_'.join([problem_prefix, problem.ident]),
|
||
'grade': get_str_dict(problem.grade, 'problemGrade'),
|
||
'type': get_str_dict(problem.type, 'problemType'),
|
||
'status': get_str_dict(problem.status, 'problemStatu')
|
||
}
|
||
# 问题操作 - HTML解析
|
||
desc_list = ['【问题描述】']
|
||
desc_list = parse_html(problem.operation, desc_list, doc)
|
||
desc_list_yq = [f'\a【问题影响】\a{problem.result}']
|
||
desc_list.extend(desc_list_yq)
|
||
problem_dict['desciption'] = desc_list
|
||
# 问题处理方式表格单元格
|
||
solve_list = [f'【原因分析】\a{problem.analysis}']
|
||
solve_list_effect = [f'\a【影响域】\a{problem.effect_scope}']
|
||
solve_list_basic = ['\a【处理方式】', problem.solve]
|
||
solve_list_verify = ['\a【回归验证】']
|
||
solve_list_verify = parse_html(problem.verify_result, solve_list_verify, doc)
|
||
solve_list.extend(solve_list_effect)
|
||
solve_list.extend(solve_list_basic)
|
||
solve_list.extend(solve_list_verify)
|
||
problem_dict['solve'] = solve_list
|
||
return problem_dict
|