report_generate.py 4.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. # -*- coding: utf-8 -*-
  2. """
  3. @author: yq
  4. @time: 2024/11/8
  5. @desc:
  6. """
  7. import os
  8. from typing import Dict
  9. from commom import GeneralException
  10. from entitys import MetricFucEntity
  11. from docx import Document
  12. from docx.enum.text import WD_ALIGN_PARAGRAPH
  13. from enums import ResultCodesEnum, PlaceholderPrefixEnum
  14. class Report():
  15. @staticmethod
  16. def _fill_value_placeholder(doc: Document, metric_value_dict: Dict[str, MetricFucEntity]):
  17. # 替换指标
  18. for paragraph in doc.paragraphs:
  19. text = paragraph.text
  20. for metric_code, metric_fuc_entity in metric_value_dict.items():
  21. placeholder = f"{PlaceholderPrefixEnum.VALUE.value}_{metric_code}"
  22. metric_value = metric_fuc_entity.value
  23. if metric_value:
  24. text = text.replace(placeholder, metric_value)
  25. # 段落中多个runs时执行,最后一个run改成替换好的文本,其他run置空
  26. if len(paragraph.runs[:-1]) > 0:
  27. for run in paragraph.runs[:-1]:
  28. run.text = ''
  29. paragraph.runs[-1].text = text
  30. @staticmethod
  31. def _fill_table_placeholder(doc: Document, metric_value_dict: Dict[str, MetricFucEntity]):
  32. # 替换表格
  33. for paragraph in doc.paragraphs:
  34. for metric_code, metric_fuc_entity in metric_value_dict.items():
  35. placeholder = f"{PlaceholderPrefixEnum.TABLE.value}_{metric_code}"
  36. metric_table = metric_fuc_entity.table
  37. if not metric_table:
  38. continue
  39. # 清除占位符
  40. if placeholder in paragraph.text:
  41. for run in paragraph.runs:
  42. run.text = run.text.replace(placeholder, "")
  43. table = doc.add_table(rows=metric_table.shape[0] + 1, cols=metric_table.shape[1])
  44. table.alignment = WD_ALIGN_PARAGRAPH.CENTER
  45. paragraph._element.addnext(table._element)
  46. # 列名
  47. for column_idx, column_name in enumerate(metric_table.columns):
  48. cell = table.cell(0, column_idx)
  49. cell.text = str(column_name)
  50. for run in cell.paragraphs[0].runs:
  51. run.bold = True
  52. cell.paragraphs[0].alignment = WD_ALIGN_PARAGRAPH.CENTER
  53. # 值
  54. for row_idx, row in metric_table.iterrows():
  55. for column_idx, value in enumerate(row):
  56. cell = table.cell(row_idx + 1, column_idx)
  57. cell.text = str(value)
  58. cell.paragraphs[0].alignment = WD_ALIGN_PARAGRAPH.CENTER
  59. @staticmethod
  60. def _fill_image_placeholder(doc: Document, metric_value_dict: Dict[str, MetricFucEntity]):
  61. # 替换图片
  62. for paragraph in doc.paragraphs:
  63. text = paragraph.text
  64. for metric_code, metric_fuc_entity in metric_value_dict.items():
  65. placeholder = f"{PlaceholderPrefixEnum.IMAGE.value}_{metric_code}"
  66. metric_value = metric_fuc_entity.value
  67. if metric_value:
  68. text = text.replace(placeholder, metric_value)
  69. # 段落中多个runs时执行,最后一个run改成替换好的文本,其他run置空
  70. if len(paragraph.runs[:-1]) > 0:
  71. for run in paragraph.runs[:-1]:
  72. run.text = ''
  73. paragraph.runs[-1].text = text
  74. @staticmethod
  75. def report_generate(metric_value_dict: Dict[str, MetricFucEntity], template_path: str):
  76. if os.path.exists(template_path):
  77. doc = Document(template_path)
  78. else:
  79. raise GeneralException(ResultCodesEnum.NOT_FOUND, message=f"监控模板文件【{template_path}】不存在")
  80. Report._fill_value_placeholder(doc, metric_value_dict)
  81. Report._fill_table_placeholder(doc, metric_value_dict)
  82. Report._fill_image_placeholder(doc, metric_value_dict)
  83. doc.save(f"./{template_path}_")
  84. if __name__ == "__main__":
  85. pass