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