Pārlūkot izejas kodu

Merge remote-tracking branch 'origin/hb/ningbozhongyiyuan' into hb/beilun

wangsy 4 gadi atpakaļ
vecāks
revīzija
ea8a87cf63
65 mainītis faili ar 83315 papildinājumiem un 3 dzēšanām
  1. 1 1
      kernel/src/main/resources/bootstrap.yml
  2. 133 0
      kernel/src/main/resources/cache/15/concept_clinic_bodypart_properties.dict
  3. 38387 0
      kernel/src/main/resources/cache/15/concept_diag_properties.dict
  4. 38387 0
      kernel/src/main/resources/cache/15/hospital_diag_info.dict
  5. 813 0
      kernel/src/main/resources/cache/15/hospital_doctor_info.dict
  6. 17 2
      trans/src/main/java/com/lantone/qc/trans/comsis/CommonAnalysisUtil.java
  7. 38 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/AnesthesiaRecordDocTrans.java
  8. 52 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiADLGradeDocTrans.java
  9. 72 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiBeHospitalizedDocTrans.java
  10. 73 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiClinicBloodEffectDocTrans.java
  11. 77 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiClinicalBloodDocTrans.java
  12. 278 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiConsultationDocTrans.java
  13. 36 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiCrisisInfoDocTrans.java
  14. 72 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiCrisisValueReportDocTrans.java
  15. 75 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiCriticallyIllNoticeDocTrans.java
  16. 70 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiDeathCaseDiscussDocTrans.java
  17. 65 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiDeathRecordDocTrans.java
  18. 93 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiDifficultCaseDiscussDocTrans.java
  19. 36 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiDoctorAdviceDocTrans.java
  20. 72 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiDutyShiftSystemDocTrans.java
  21. 83 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiFirstCourseRecordDocTrans.java
  22. 54 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiFirstPageRecordDocTrans.java
  23. 90 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiLeaveHospitalDocTrans.java
  24. 36 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiLisDocTrans.java
  25. 26 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiMedicalRecordInfoDocTrans.java
  26. 460 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiOperationDocTrans.java
  27. 40 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiOutDepDocTrans.java
  28. 36 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiPacsDocTrans.java
  29. 73 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiRescueDocTrans.java
  30. 73 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiStagesSummaryDocTrans.java
  31. 362 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiThreeLevelWardDocTrans.java
  32. 305 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiTransferRecordDocTrans.java
  33. 52 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiVTEGradeDocTrans.java
  34. 282 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingbozhongyiDocTrans.java
  35. 41 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiADLGradeHtmlAnalysis.java
  36. 183 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiBeHospitalizedHtmlAnalysis.java
  37. 71 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiClinicBloodEffectHtmlAnalysis.java
  38. 72 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiClinicalBloodHtmlAnalysis.java
  39. 120 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiConsultationHtmlAnalysis.java
  40. 57 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiConsultationRecordHtmlAnalysis.java
  41. 56 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiCrisisValueReportHtmlAnalysis.java
  42. 49 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiCriticallyIllNoticeHtmlAnalysis.java
  43. 56 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiDeathCaseDiscussHtmlAnalysis.java
  44. 51 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiDeathRecordHtmlAnalysis.java
  45. 92 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiDifficultCaseDiscussHtmlAnalysis.java
  46. 56 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiDutyShiftSystemHtmlAnalysis.java
  47. 59 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiFirstCourseRecordHtmlAnalysis.java
  48. 14 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiHtmlAnalysis.java
  49. 243 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiHtmlAnalysisUtil.java
  50. 64 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiLeaveHospitalHtmlAnalysis.java
  51. 62 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiOperationHtmlAnalysis.java
  52. 101 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiOperationRecordHtmlAnalysis.java
  53. 90 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiPreoperativeHtmlAnalysis.java
  54. 56 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiRescueHtmlAnalysis.java
  55. 56 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiStagesSummaryHtmlAnalysis.java
  56. 91 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiThreeLevelWardHtmlAnalysis.java
  57. 56 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiTransferIntoHtmlAnalysis.java
  58. 65 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiTransferOutHtmlAnalysis.java
  59. 41 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiVTEGradeHtmlAnalysis.java
  60. 12 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/ez/EzAnalysis.java
  61. 41 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/ez/EzClinicalBloodAnalysis.java
  62. 21 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/ez/EzDeathCaseDiscussAnalysis.java
  63. 40 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/ez/EzOperationRecordAnalysis.java
  64. 337 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/ez/EzXmlAnalysis.java
  65. 143 0
      trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/ez/util/EzXmlUtil.java

+ 1 - 1
kernel/src/main/resources/bootstrap.yml

@@ -15,7 +15,7 @@ spring:
     active: local
 
 qc:
-  hospital_id: 1,2,3,4,5,6,7,8,10
+  hospital_id: 1,2,3,4,5,6,7,8,10,15
 
 logging:          # 日志
   config: classpath:logback-spring.xml

+ 133 - 0
kernel/src/main/resources/cache/15/concept_clinic_bodypart_properties.dict

@@ -0,0 +1,133 @@
+LAphuzvX0+1zUunA7M09Hw==
+wGKkm1Axrl8=
+KkqtLy22gBtRq6Y4vkNXyQ==
+sPonp8kD0PlDfsMr80o2tQ==
+Dp+xJKT1n8g=
+ZCI0+I1MKLGoU+yPtmhbJw==
+DOXrtCrKcXSFIWuMj59JFg==
+01OrraAAmcE=
+MfpZ5926ns4HjnX6dZF4Ew==
+eJVLnFBt3h4=
+MCVPu99GbLxp84i3DCFu/g==
+2Hhy8O0hODI=
+5r1+UeeRdz0fVJH7s8MZNQ==
+Q2fNzojA4fA=
+vW3dTpk0tFiQiw2jWjwfPA==
+MNTZtG8f9LQ=
+ogVQVbsCHOI=
+Ce2UXUa+3KsfVJH7s8MZNQ==
+wmRvRyr6N5yg1rmFJe9Z2g==
+V7VA3KYNqxQ=
+aC5xv6h4kt5c5OTNuAf37Q==
+Z0C+uRrbTghAxhoGdRmsYg==
+Rpy4rqBnq0xXxvYNaFTw2Q==
+I7vcOPzkQOo=
+MAJlaU83a4ioU+yPtmhbJw==
+uUfXVwqAQBs=
+TvEGDdLx11J/ufBPhFj0Ww==
+dn2Qsy3GvOgfVJH7s8MZNQ==
++ojTIp5v4bQHjnX6dZF4Ew==
+c06lMwdsMGY=
+zfymW7X/poA=
+hj3oPwd2A8wfVJH7s8MZNQ==
+6F5GQVOYgyui7/G0BOLWvmb0NA6xAPvZ
+eh0gnqWcoodAxhoGdRmsYg==
+HBi62z4VqkA=
+eOtp99ION5B/ufBPhFj0Ww==
+PQlTF2j6ne2bIZQhpl3bRg==
+W5f3x2qRae4=
+0dseB0FG4fk=
+9Oafm8Bskj0=
+z3AdaerZRVwfVJH7s8MZNQ==
+zdISnbEr02KedPJCHzSuhw==
+8wtXCXbnt2cfVJH7s8MZNQ==
+DvDTv3eRhQxM/KLa6uVUSQ==
+hK5uiQNYMutrynAbi7Nl7g==
+93ZjDiJwkDEcuBfsuGV26Q==
+H6hvNux0DMVfB2OTCSmksg==
+oapSrFpo1xzKZlVMzaya/w==
+cA6kPjEpsoJc5OTNuAf37Q==
+zK3IJj4OCNK63Wt9pi+oDw==
+eE2lKBuqkGxc5OTNuAf37Q==
+He8DX2NE4io=
+xrxCCtiW1kQ=
+1IKx7GtShHg=
+WlxWJO1bvWM=
+JB2E9WXZ5MgUCMxgY7oByw==
+enu6avlk5YoG1YmqGz3h9g==
+XvltMqvZ0rG4vnEZ8kLHbg==
+LQ4RQ5c6TvEfVJH7s8MZNQ==
+3IQA5HUrujc=
+13MHrUqG1pcfVJH7s8MZNQ==
+qDJCWQ+e+n6edPJCHzSuhw==
+xDC1Ti9ss3U=
+ovmPnAT+BYs=
+GgfSGissd7DNjYGroWncAQ==
+oujtg2YhATc=
+2IQUTK7lEyM=
+8iRAY6UGp0YVY3fFFOFg2g==
+Hif1tO4NCkk=
+pnIIwZAPIIPBAIkf/X0ufw==
+JJw0vZQlXuxp84i3DCFu/g==
+aGH61MJKMS7BAIkf/X0ufw==
+mA0dp7Zpk/MfVJH7s8MZNQ==
+el7aO7TjFOkHjnX6dZF4Ew==
+u7zlp9tdgNmRKVPbAeWYEg==
+9zqzljbiYu8=
+6kIlhnYnjOC/WZ1+qt48kw==
+bYP4eZXu1JMfVJH7s8MZNQ==
+38rBhrBd2ZA=
+/i2W9Ldeb+I=
+CMHCsSygook=
+J1XqrY7xMtY=
+oStcY3ItFdZp84i3DCFu/g==
+idBQS4aIrNa5fhcvExqbXw==
+DwvME4SMq1+bOR+EdoRoFg==
+tr3mC/s6c9sVY3fFFOFg2g==
+H45LTbfORk8=
+H8iHeeS1rXY=
+MOuKy1wkq4b7Dji9AZqQog==
+De0vhPcQSMBYGLQ8FmimcA==
+3BvyzjY734Zp84i3DCFu/g==
+HM89DEXwIpZbnoRDJ143bg==
+rz3JZr31IyPYt42Urg1Jzw==
+syl6GnJDiUoHjnX6dZF4Ew==
+aD5eU1o4MmM+03JbZpPE8K74oEbqwDfN
+OgJkiiRLMa0fVJH7s8MZNQ==
+36HIq5sBqNHNjYGroWncAQ==
+PTX9F+XFiHM=
+FXYCcRyAS3o=
+QqPqll5V3q+ken3TgiVM7Q==
+MgaLJr/9B1a4ACWlx8X4SA==
+SUTiIJK8tCefXEA0j/uq7Q==
+PV15+/MoQVT69Mxpvjn8ew==
++37KuiO62gI=
+OxBAAUKmMB00iPLsFnfW9Q==
+TkKCqeWSukfkqT33kNdg7XtqtAiTi3CE
++XIIOz+kxpCUAfTSDenAAg==
+noFHr1hkTNjL15F1MBXHSA==
+Az2U7M6QU8cHjnX6dZF4Ew==
+ypYq0llNvxtI/qHgUfgHEQ==
+JPNNI7Mn7GkOCoFD2N6+gg==
+0sR5tvt5nTkfVJH7s8MZNQ==
+qDsVL3hjCgxefGaE90oS7A==
+CCwoTxnngSQfVJH7s8MZNQ==
+imwDTINwXfjYlg1d8mP6iA==
+eXtihU+dgoH+XFxDriiYrA==
+qIWekMxNvsIfVJH7s8MZNQ==
+KZUjBH3QG1G82j8JYvRviu4snVNHMRDd
+qJUZMtAw/WiAhcQlN1BQqQ==
+lwGHWf1Es9kfVJH7s8MZNQ==
+H5rQ7wE9KYA=
+Ia0GAZyPZmQfVJH7s8MZNQ==
+QUV0SLvhn8MkVYph1YGRZQ==
+KSzY6T6+c7txOA0SFqxXjw==
+rmxr1ubN35NRq6Y4vkNXyQ==
+9ON7f+cfbFKQDSBz6+VqxQ==
+RRmtNZvkAQNdGy/Xru8l0w==
+tEpz4Ws2I3E=
+8d20YPKZX9MHjnX6dZF4Ew==
+KUKo8hZ4qfUfVJH7s8MZNQ==
+V8p/97BlQ1uBggh8N37P8g==
+6ByZH6ejZBQHjnX6dZF4Ew==
+GwjNkWrksZShsfR9iW7TiQ==

Failā izmaiņas netiks attēlotas, jo tās ir par lielu
+ 38387 - 0
kernel/src/main/resources/cache/15/concept_diag_properties.dict


Failā izmaiņas netiks attēlotas, jo tās ir par lielu
+ 38387 - 0
kernel/src/main/resources/cache/15/hospital_diag_info.dict


+ 813 - 0
kernel/src/main/resources/cache/15/hospital_doctor_info.dict

@@ -0,0 +1,813 @@
+6hT1OVoaNlagM5YH+yDTtfXoNDUrhiv7
+Fh1JlwgrF2zu4Pxoj58PNbgGJlVSiNEL
+AOOWeC5zUWxL86ojSlzKJqa1qpic2S+n
+z4cG6L1+zR1o/zq5s0YgzPXoNDUrhiv7
+xc4yRK3jS2GtC0YcG9FdC/XoNDUrhiv7
+T+JAG2TD01rODl/ivj20vdwlBhK2CH9tW6M7h6GPKpQ=
+qYZmLFYjnUdo8Gf+NV8z8fXoNDUrhiv7
+xqNCqDB4gjfPCalK+86QLLgGJlVSiNEL
+gyAiWVLPeo8n2WDvor0mDPXoNDUrhiv7
+WnC/fPTenKKj6vNuWukNGvXoNDUrhiv7
+EJu5L3xchUmmGJWwPB3qBbgGJlVSiNEL
+NnZy5Wl7M7YtVgM7HwWgwrgGJlVSiNEL
+7V/9VwpcYcsv8CMlIIAJgrgGJlVSiNEL
+z4AM2WpNw/a+iINuFdS3wLgGJlVSiNEL
+JDOxipZrsgakDJVzUpVGyNwlBhK2CH9tW6M7h6GPKpQ=
+h5BMuTUa930n2WDvor0mDPXoNDUrhiv7
+C5huix+K8TXZabIkyJTnkLgGJlVSiNEL
+LaqhWe3CXiR/agBuRiIq2H+Ay2htUmISQfh5YR4fO9M=
++TlsoNGtua8SMaA4+jz6kLgGJlVSiNEL
+ngeGqo761ZevG6gyJwoDPbgGJlVSiNEL
+IYqF0LUtSl9GMbKieRsuUgtgcgd4YfgS
+wjYxx1LCBeI3U8qvF5VqlXqts9tVT1Ku
+FQubT9ZjJrTZx5fTRR/qO7gGJlVSiNEL
+koZbwX/Hgw22i+SMvNz1nPXoNDUrhiv7
+fTBw/cbsiJoQ4PZcyIDqcvXoNDUrhiv7
+3yioTk0452BeenVEi9gwK3+Ay2htUmISQfh5YR4fO9M=
+ycbxmeIS3p3LW+sRFeNERLgGJlVSiNEL
+t3Rc9WzQtGBzle+T5q9f5qa1qpic2S+n
+TWm9AztYc9Un2WDvor0mDPXoNDUrhiv7
+FOnjVlt6qt/YQXSIysQsDrgGJlVSiNEL
+CNljJhWl34rhGkT51NwbkLgGJlVSiNEL
+NBKt3QQfKihYNGCKqZ68ArgGJlVSiNEL
+3FQDFc4iZndBM+MxxBGBLLgGJlVSiNEL
+qIkGX9KFbwtG6+EhqZxzbbgGJlVSiNEL
+sCFTj/6v3rsCeiSpU3a8+7gGJlVSiNEL
+uR22qOT7UfX62ovjwb6WvvXoNDUrhiv7
+sqY7GyImuvGMChJvsMA6/nqts9tVT1Ku
+R4nU7Fwh7euT2jP4kHoFurgGJlVSiNEL
+2VWViiBmoNTSa8WcotP3L7gGJlVSiNEL
+Zit65qT7oS6j6vNuWukNGvXoNDUrhiv7
+lWSMHCBFZVds9ivh/ZJUSbgGJlVSiNEL
+WQoHBvs2D0aQjlc6WO5+YNwlBhK2CH9tW6M7h6GPKpQ=
+2HkpvEn+N6UEN8L+RZAXXwtgcgd4YfgS
+E0UAobjqRTZV8L5Fbzfst6a1qpic2S+n
+vEWengXBpmKoFegasCse53qts9tVT1Ku
+0d9sboFEsxuhs413x2g1jLgGJlVSiNEL
+QnuEUWuwGRao1SuRvy4n46a1qpic2S+n
+N+tqdHGpn1/+6KDrJpNNM/XoNDUrhiv7
+/mtCv4H8QmC461o0a+M5laa1qpic2S+n
+Dbgo7TG2keCtC0YcG9FdC/XoNDUrhiv7
+OC9+pnKVJoeUgIINajRGmKp1f11xx5q7
+TU9eANAnd3rWZYQinuZQVKa1qpic2S+n
+/oF/hDLrcQDu6S5wdO50fdwlBhK2CH9tW6M7h6GPKpQ=
+1pbdZ3iaMRSj6vNuWukNGvXoNDUrhiv7
+eTSlPhNeB+Zo8Gf+NV8z8fXoNDUrhiv7
+X5JTzMlYUv5Q9vSlqkARPdwlBhK2CH9tW6M7h6GPKpQ=
+8hzP3UeymdOZZ4LT6eBp5LgGJlVSiNEL
+FN1V2e2tHaKKactkljG/Z9wlBhK2CH9tW6M7h6GPKpQ=
+iAWJ8rqriiqBuaEy5Iwte6p1f11xx5q7
+zWWFbBoRuddrPvv+GqGMsX+Ay2htUmISQfh5YR4fO9M=
+7jAKa2EZgluFBtMU8CtI93qts9tVT1Ku
+DRnv2B4u8RRlcaN1KLQPVHqts9tVT1Ku
+0CEciftQCXxj99HTi8QNbrgGJlVSiNEL
+cv3ODupX0GNZohr5KT8XHNwlBhK2CH9tW6M7h6GPKpQ=
+PdB3HucbQQvK/+Ck99lOJrgGJlVSiNEL
+TSqgo6yzH3cYyJZgVYGMgKa1qpic2S+n
+Q9jaRKSWwQB1bZVCyUz+WtwlBhK2CH9tW6M7h6GPKpQ=
+N4dPgv72Czjol9qPihQJtbgGJlVSiNEL
+ANWVothVF/StGnFER8fSr7gGJlVSiNEL
+ZywP/q/7UeXK8QOtoLb267gGJlVSiNEL
+9+KKMiJ3a9QQVdpOFWwfObgGJlVSiNEL
+A6HmRnzpHiGHMKYym78eObgGJlVSiNEL
+Sub/dQAcDI5+QPLlJb6W8LgGJlVSiNEL
++AR4QgAydtq1ZuTRcHwqz7gGJlVSiNEL
+E+9taPm8VbeCKISlo491frgGJlVSiNEL
+BmvC2XQHjjZCKYcdpYSTLbgGJlVSiNEL
+utLTjusWLRvSKFvD/F/957gGJlVSiNEL
+iapAsnjd1A5TP02jZeu00rgGJlVSiNEL
+5B/1qFQozkXyL9M8ZTxdNLgGJlVSiNEL
+GefvOQcOUEa2i+SMvNz1nPXoNDUrhiv7
+4oY7dTMyzj36VQCyPzbS67gGJlVSiNEL
+ttmf8Cl34Z97aqSVCYnzy3+Ay2htUmISQfh5YR4fO9M=
+sHO0Ko4VQU/9yVpOXBOjvbgGJlVSiNEL
+YZOBIkhtSdTim1B9ItLebLgGJlVSiNEL
+ZBSY5/Z69UXUcGh2DIWJgPXoNDUrhiv7
+B2FOXLWyTBn+6KDrJpNNM/XoNDUrhiv7
+kyboDJ/S9NNKQoLhT6+0RLgGJlVSiNEL
+3NKYDYemxllB3HqKlrvyhbgGJlVSiNEL
+peRLhvzCNCX62ovjwb6WvvXoNDUrhiv7
+iQW7oyfolqtaGbK8bzqvbLgGJlVSiNEL
+yJa5klV9HR/mbUBSO6b8UrgGJlVSiNEL
+Z+vh8o7eIaJLaMfoL3bNEdwlBhK2CH9tW6M7h6GPKpQ=
+ttaT2ETdhNvPed+g9QcOlbgGJlVSiNEL
+pH6b8tPC/CL4IDcH9vYLJ+ZVB7mY8h37LKs3fnGbwV4=
+xJlFntLVQIOm/zGwF/KgabgGJlVSiNEL
+wNbMzABo1G6D0eKcppz07bgGJlVSiNEL
++uuGgyymrkXHTTGH7fxwnfXoNDUrhiv7
+WIM5Oys2CeCtC0YcG9FdC/XoNDUrhiv7
+gAe/4jW6dE+xy1eU3/0RsOZVB7mY8h37LKs3fnGbwV4=
+mO7yGoXkpsrrqyJJG4fBgqp1f11xx5q7
++VwLubUgn9NkR0LxB6d2UrgGJlVSiNEL
+KEd1opcfol1MYLkt9GN95rgGJlVSiNEL
+oqAceMVfjBjOyc9g8i214twlBhK2CH9tW6M7h6GPKpQ=
+tYSAIHSf5LhxqoIchdz5NbgGJlVSiNEL
+UNxTFQ/lRTmuhUYeF6H0QbgGJlVSiNEL
+KC0lnuWnhX2j6vNuWukNGvXoNDUrhiv7
+Ptk2qZXETnqtC0YcG9FdC/XoNDUrhiv7
+bLN3QJXySa7+6KDrJpNNM/XoNDUrhiv7
+iozrrJfSVeFdNuPyQpRzXk+5TjAW0UK0prWqmJzZL6c=
+Fo5+2aMHjPY7tLIJcyGULbgGJlVSiNEL
+fhqibOXDyP8eVOg+NwOpzLgGJlVSiNEL
+m0XjTYO9NVEgpTf7FdisstwlBhK2CH9tW6M7h6GPKpQ=
+XdhiJplmX1cz0fmFDQscA9wlBhK2CH9tW6M7h6GPKpQ=
+UnOwK6Q5xE762ovjwb6WvvXoNDUrhiv7
+YYB2Ur7UwMqaWfjcp7IEjKp1f11xx5q7
+Y0rhB8hsobYk2c5rjChcxrgGJlVSiNEL
+acSpCEbs63eavitBRycrgbgGJlVSiNEL
++hhPOWZxVpgNc4jfM1Ex1LgGJlVSiNEL
+nS2PBFVjU5TZabIkyJTnkLgGJlVSiNEL
+2IO8aZbiI54Q4PZcyIDqcvXoNDUrhiv7
+ABsoMzYRFf+n1XBAC0KW5LgGJlVSiNEL
+S5QWNslBBVd+xGSUV4UpX7gGJlVSiNEL
+/s/90ESeV66zil6DkHWhgrgGJlVSiNEL
+IZuj22Sd4LOzjFbf7t4dWLgGJlVSiNEL
+VGlUHbOkKxRLzXZVGEU9YLgGJlVSiNEL
+NS9Tav6S+ZcbJ+XdHTgBZNwlBhK2CH9tW6M7h6GPKpQ=
+6XQ+MJ6Va4+jYM4ZVf5/oLgGJlVSiNEL
+w0UdY92mY+bHC8sEl1kYigtgcgd4YfgS
+0adCG8MGDPRINq5d88gIGbgGJlVSiNEL
+OWLFxQFUVy1c4DipzL8Xv3qts9tVT1Ku
+nX2gyuDX6HRIYh/spKcjE3qts9tVT1Ku
+YJPaAMTXMSbkWTESjzKU8Xqts9tVT1Ku
+vX3E7ayXLE/rLdDMB/gpBLgGJlVSiNEL
+3S76JqWInnJawh3tvgMCVPXoNDUrhiv7
+J0AHF2RoBTm5WZkOBuG0U7gGJlVSiNEL
+1rTy5ZH91dLUcGh2DIWJgPXoNDUrhiv7
+Fzzi0NOuSjH3wlnHP/DPWLgGJlVSiNEL
+l0xN5zgstTUGtz0VGJvsd7gGJlVSiNEL
+74GMHNSFqBPyL9M8ZTxdNLgGJlVSiNEL
+IphgHxz25yatC0YcG9FdC/XoNDUrhiv7
+2pY5aPkl5p7MOve1ljC1HAtgcgd4YfgS
+oeHAjXv8kYwtbzRx55ZQ9bgGJlVSiNEL
+d2p2J4EHhX49qqCQTLS7OdwlBhK2CH9tW6M7h6GPKpQ=
+iv1mDnmdrxgv2cKb46nP8Kp1f11xx5q7
+1T+d53x/r4t6jVuFqnzlOrgGJlVSiNEL
+O1h3xT6OvyyvrjLEXxRB+LgGJlVSiNEL
+zvfpjiJEUkBO+5duBkZT83+Ay2htUmISQfh5YR4fO9M=
+u5fvZSVt2hXZ/+Y1o9dNUbgGJlVSiNEL
+mh4hK0en3c27l7hemHZDO+ZVB7mY8h37LKs3fnGbwV4=
+vqCfZfW4TgtGkckKZ9vWlXqts9tVT1Ku
+SXxYorjHl6bAlZjvSA3xVbgGJlVSiNEL
+re5iXICVGVMo4rLB7PChEPXoNDUrhiv7
+gyUem54+c7+7AAyFgsw4zaa1qpic2S+n
+i6O3tx4FQor+6KDrJpNNM/XoNDUrhiv7
+PV/M9ZSgi+pwL/UURlBWSbgGJlVSiNEL
+Firap1lsAucnHRQU+iKhHsWAX6LVNdgPqnV/XXHHmrs=
+ngWGN8DKwIeOkLbSf9uvCrgGJlVSiNEL
+ORVVuKwnmXapqcqRjrARUXqts9tVT1Ku
+Qxy45pNfTtJyNsGw78/xrap1f11xx5q7
+PRDHeNKqLxJxY4f0Y/CzXbgGJlVSiNEL
+NmVEYlkVHlOZyh/3tUTDHqsCWjXCNazg
+k4bLsZ1ZFv9LgY/8xLFqNbgGJlVSiNEL
+cDa99ESEVzJc0wjeQ5nV+LgGJlVSiNEL
+rwcq50XHVDZGMbKieRsuUgtgcgd4YfgS
+HNSRFWUvtkzswpdOWK5M4bgGJlVSiNEL
+/4PqiiITu3qAXVHfBA5YXaa1qpic2S+n
+9DJim9tUTPBSpHwK6tV0RdwlBhK2CH9tW6M7h6GPKpQ=
+FYDHiHTEGbKyRBK94oQGEbgGJlVSiNEL
+ekRKIEAC8UaF8PjblcEC2bgGJlVSiNEL
+nKXcdMN1pP1aOrvqKsrz8aa1qpic2S+n
+Z2KaAqn9JOo/0IWG5A4qQ7gGJlVSiNEL
+BNrvTLhqFE92F4X3owYtstwlBhK2CH9tW6M7h6GPKpQ=
+tEFiQ1SOEqbJGEoopCOxmLgGJlVSiNEL
+2srRFw/HxsCErhjmTH1BIvXoNDUrhiv7
+hMp69llMq4WDxIBGg7Kg3qp1f11xx5q7
+3KuYs0O6O8nK8QOtoLb267gGJlVSiNEL
+WLrkbbfFPbsF9DtBDTlbGdwlBhK2CH9tW6M7h6GPKpQ=
+aYFQ8P5XJMlzOKdyDhcjJvXoNDUrhiv7
+O/pNF6lEEXrK8QOtoLb267gGJlVSiNEL
+6DUTLb1+MhmZrz4bhA82ULgGJlVSiNEL
+Ej06mCNlnza0N/SZL3DWMLgGJlVSiNEL
+4Y5bS/F5qX6nZidAXRTlTrgGJlVSiNEL
+LQZYz44dh/yN+/S6BZ2qxtwlBhK2CH9tW6M7h6GPKpQ=
+yq8Yh0bjf2wtb0QuxfJqRXqts9tVT1Ku
+MmyZ0rIWvxy/5uPBHaxTJAtgcgd4YfgS
+I2co2kOKWdB5b6sFmirByLgGJlVSiNEL
+clh2XuB3FepnvyNbq+MLgLgGJlVSiNEL
+XuMh355fY+on2WDvor0mDPXoNDUrhiv7
+qO6Xw9fulfDL7lot+sXMWbgGJlVSiNEL
+s4zT8FrA51FOloiPYHyORnqts9tVT1Ku
+5XNYcTDnBhAt6IGJt6PrcYyHjcJv2FpA
+AQp4O9wL9k/zfwIwx7pO8rgGJlVSiNEL
+3IVUJ8Vrfggh2pbOyoCWCLgGJlVSiNEL
+22A4KSmV3eEFDeW5PX1LU7gGJlVSiNEL
+j5VgAye5nFcQ8EE2Ip/OnHqts9tVT1Ku
+bCB/d/O0tKmw4ZqjfsNMO9wlBhK2CH9tW6M7h6GPKpQ=
+1vtHxM/Gzbb76f3+iJXYkfXoNDUrhiv7
+OjLzFaltJOeFLv+u44+bCwb4W33SKZJwSmARnfpRl/s=
+B6UlrsM5I09fN8j5j2XDwLgGJlVSiNEL
+P5t31/YRzfVXKw+1CBXs47gGJlVSiNEL
+65C4svHUHShq16mc+jPvT7gGJlVSiNEL
+IjIypEClIYbaB3okOlhe0bgGJlVSiNEL
+pQ9QhDVKNmX+6KDrJpNNM/XoNDUrhiv7
+mVZQ8Rzwzi1h61yDR+g317gGJlVSiNEL
+/AQ59jOLyXIQ4PZcyIDqcvXoNDUrhiv7
+/cKn1RuS6/60R0LkKceDzn+Ay2htUmISQfh5YR4fO9M=
+MKuA+Y7zKQ9EXszumP67mrgGJlVSiNEL
+GXF/P5x/gPeaNPXtMKa6f7gGJlVSiNEL
+AfwKS7kCpOStC0YcG9FdC/XoNDUrhiv7
+awbGicrRkgmuRuO8Iw10G7gGJlVSiNEL
+PjcUiO1eRv2i4W7bwS2f07gGJlVSiNEL
++ulpjp8r1gfM5hmwK/ZVzbgGJlVSiNEL
+4OfBGK/WU2r+6KDrJpNNM/XoNDUrhiv7
+9zIxvYLPOCVUI5kJCyLnyrgGJlVSiNEL
+UeegLU3bsgMghmYFRr41dLgGJlVSiNEL
+gHxY2ZztwOwC37GBtnQaaasCWjXCNazg
+OAjPXKyr5sGCKISlo491frgGJlVSiNEL
+RGn7yFg0vxFKmKSW1cLnrbgGJlVSiNEL
+dvdyjiRPbJyRvsF0zx4GcqsCWjXCNazg
+Wrxztwf+wS3S5qMXxAfqZuZVB7mY8h37LKs3fnGbwV4=
+6QU34YMaYa4EBIyWhbshVLgGJlVSiNEL
+J0o+6RD2Tn8slWnNkv5sUrgGJlVSiNEL
+ZFYu9Wh7W38UKf3L6cw6i6p1f11xx5q7
+Ld2aAtbb3WKD0eKcppz07bgGJlVSiNEL
+oDCQHFNA4fY5iei+2/SOSrgGJlVSiNEL
+tYlIG0HLwv/9krvLV1nKargGJlVSiNEL
+yaR4TMKD+lv+1abMuL6PALgGJlVSiNEL
+gJs/g6YjBO96a2o7ERffvaa1qpic2S+n
+xOnWtGfLTYLo1kK5QTOKi7gGJlVSiNEL
+Y70BKnyskZ3iVXvaF2dCH3qts9tVT1Ku
+wWdh7zMNjTMU48aEfIPucrgGJlVSiNEL
+dFghi4xL3UlErXgHbVuHDrgGJlVSiNEL
+5K+60KseO9C+dX/yNciHJqp1f11xx5q7
+EqYnrxF52mFcQokajwqsQ3qts9tVT1Ku
+RJ2KWgi8FOHqXB9G2xFi3qqHdeHVfA/zC2ByB3hh+BI=
+sAEkRS35hib4zUqiLkaDOSCOlDI1vq4kW6M7h6GPKpQ=
+99HPlnjIbL1br8scIdXxhCCOlDI1vq4kW6M7h6GPKpQ=
+OPMJvmDYUQ3FYIHyLzYDkNeTR/XZs3VKwLWSZ8yoDks=
+ks1KeswX8+Ojg6v0O7nGq8WAX6LVNdgPqnV/XXHHmrs=
+o5g+GnMmmfBGDAqyzJowuyyrN35xm8Fe
+K/28E85J46TzBOxg5UkU25dkzcPpM0pSUpDYf7GcLwU=
+KioIf/vwSjFNXiucgF9Qb8Y5DkwsDicsSmARnfpRl/s=
+yB13ip1+ff4obvE/ESfyQRkRZaY/U9MJaW/3PQhnPR4=
+NBO3C8TJXneRPqwAptcVSMY5DkwsDicsSmARnfpRl/s=
+8ox/3+RrftbtCxtzDiOymh2An0yhn8nnMHSvDnioeQ8=
+NQfbVoOWQZbIw0ocFppZqiCOlDI1vq4kMHSvDnioeQ8=
+Ycj4KVq9QMinmIpTern3N5dkzcPpM0pSUpDYf7GcLwU=
+xTORlJOgaiHz4dSuUu4HzZdkzcPpM0pSUpDYf7GcLwU=
+XHjIqXRjURvcSdPuM3cbUx2An0yhn8nnMHSvDnioeQ8=
+mMxR4jiMJWPuqUqHjKeTEKOtthW9wiK6UpDYf7GcLwU=
+2KJ3444pakYBOvmM+ANn4cWAX6LVNdgPGHx0E7OBc/Q=
+xeDUBoRpq/grwvBRB45y4aOtthW9wiK6UpDYf7GcLwU=
+2zvR3L6ORIL/CqshHti1ehkRZaY/U9MJaW/3PQhnPR4=
+YThhFIviAU8HxcQYhp8tjqOtthW9wiK6UpDYf7GcLwU=
+3Sr8cksfK0Kp/v3EqUGwkcWAX6LVNdgPGHx0E7OBc/Q=
+KlVpD76hVvOfgGcLCvKeC8WAX6LVNdgPGHx0E7OBc/Q=
+JJYZStjJZ5wX6+SikxqoQcY5DkwsDicsSmARnfpRl/s=
+bRhSCteG8B4/fZwryJpXi8WAX6LVNdgPGHx0E7OBc/Q=
+gWfjY3ScbvzTMWSHDC6i6Rh8dBOzgXP0
+bsyJCRSx4+OPFvNYk0OZICCOlDI1vq4kMHSvDnioeQ8=
+JS2zAlu2T38H0IvzczhLLZdkzcPpM0pSUpDYf7GcLwU=
+GW4/5GQMgaon2WDvor0mDGTgEgmQimDg
+hL7sUP2BwO5lwspzsJKosRh8dBOzgXP0
+Hb65TsNASpaa+N1ykeW5rz0okq5DXPoQ
+CvPpv98PrMYLs7bHqkYTe8WAX6LVNdgPGHx0E7OBc/Q=
+ga7f4a8i78GVuOZ0pfuwLqOtthW9wiK6UpDYf7GcLwU=
+G6+Vt8WjfoWoRlBdkBJFssWAX6LVNdgPGHx0E7OBc/Q=
+5wIaB+xDhEE1aRPPSnB+UsY5DkwsDicsSmARnfpRl/s=
+/7NNhd+h32PMFIu3ici9MqOtthW9wiK6UpDYf7GcLwU=
+nAwYCEPAd9I2Ygj2xVdZclKQ2H+xnC8F
+5XNYcTDnBhBG5Xd2EtrZYfcLCvtq0hz5
+U4j2bqKyWM9eewRh/Q0v0oMEakZ0IrV8
+D2IwcL16bPsJo73fVyHyOR2An0yhn8nnMHSvDnioeQ8=
+BJNbIWEULni5Ij/FLINEgB2An0yhn8nnMHSvDnioeQ8=
+UUfcio9lAXTXPUOJ17cMy5dkzcPpM0pSUpDYf7GcLwU=
+guVAmxBP1rRzl0kwgGEd5R2An0yhn8nnMHSvDnioeQ8=
+tpJPSuM/iEdcJh+DXDsSkh2An0yhn8nnMHSvDnioeQ8=
+GkTJU9fAWf0dq7Bvuix/2h2An0yhn8nnMHSvDnioeQ8=
+LMwGnb8jOApFKiHwttsti1KQ2H+xnC8F
+3oFf/xWDe+UQJFW+to7FHB2An0yhn8nnMHSvDnioeQ8=
+QQJyIUQ9FKfM4FIKdZszt6OtthW9wiK6UpDYf7GcLwU=
+vTCge+/gzv/3gibjVSs7MaOtthW9wiK6UpDYf7GcLwU=
+taX3Gxi3fzENP13NUcUjU6OtthW9wiK6UpDYf7GcLwU=
+65va6QU4eu4vsjWFDkbuyaOtthW9wiK6UpDYf7GcLwU=
+z84AVL2ZXR04dzsy/MkHyB2An0yhn8nnMHSvDnioeQ8=
+xCEjy0RPh4n/CqshHti1ehkRZaY/U9MJaW/3PQhnPR4=
+M6TT19kPijy0LR+RcM3klh2An0yhn8nnMHSvDnioeQ8=
+T5AUsdP08nxQR93ST55FRx2An0yhn8nnMHSvDnioeQ8=
+yAl7R1nbx1Dh8fcp8Vmb5Rh8dBOzgXP0
+rvxVolqSwBouKp8EMOTcO6OtthW9wiK6UpDYf7GcLwU=
+hTBUpeaw/iSRPqwAptcVSMY5DkwsDicsSmARnfpRl/s=
+uQvy2xGkLulEqQk8jWf3hMY5DkwsDicsSmARnfpRl/s=
+Hq9NuO/+/371RkTRK3SA0B2An0yhn8nnMHSvDnioeQ8=
+QHD9x0dz3QhHeT8qX4gNwMWAX6LVNdgPGHx0E7OBc/Q=
+/VhEByiN/bOBOENZ7wsn46OtthW9wiK6UpDYf7GcLwU=
+ngWGN8DKwIcFXYdHSJbsQR2An0yhn8nnMHSvDnioeQ8=
+dkyHjkLEgw0RQt5nfTjx3x2An0yhn8nnMHSvDnioeQ8=
+RnQ26/5KkzQIRYJtJ6vqvqOtthW9wiK6UpDYf7GcLwU=
+VXrq8zAvYjKfe0C+ySB4uaOtthW9wiK6UpDYf7GcLwU=
+eCC6Dl7OTgwXESDttwlnjR2An0yhn8nnMHSvDnioeQ8=
+rXZRli0vX6CYk7S43yMNsqOtthW9wiK6UpDYf7GcLwU=
+7V3EkTO65+UrwvBRB45y4aOtthW9wiK6UpDYf7GcLwU=
+ZxHoPTuV4+cAndunemKUz6OtthW9wiK6UpDYf7GcLwU=
+EqXqbLH1d0NhqlshazZ5YqOtthW9wiK6UpDYf7GcLwU=
+HRgf2eKZpRoz/wK8Xgk4fhh8dBOzgXP0
+56IdglCcSLSN89cL5n6BOBkRZaY/U9MJaW/3PQhnPR4=
+YFKwZQ0tlkZSJ/xoBTITYj0okq5DXPoQ
+xwSXGAFAcsNVaTv+5quJRh2An0yhn8nnMHSvDnioeQ8=
+r1pNwRvmUDr15UPyX+PVh5dkzcPpM0pSUpDYf7GcLwU=
+DBkwcY05ySNyj4sRMljGT5dkzcPpM0pSUpDYf7GcLwU=
+swrqbhPkSlcqWaeElU15ypdkzcPpM0pSUpDYf7GcLwU=
+QpmzpxGw4NnO+iL/axEY6MWAX6LVNdgPGHx0E7OBc/Q=
+UURppwkU66+rTjL0eQamZ8WAX6LVNdgPGHx0E7OBc/Q=
+/Ip3HPcdFke6Y8rxRTNAzYMEakZ0IrV8
+G9hnx2OUgDhxVImAwcpxIRkRZaY/U9MJaW/3PQhnPR4=
+qhmV4uiNzGMBtld9wMpcehh8dBOzgXP0
+Ta8Db/paj7nflRdTHJ9yxZdkzcPpM0pSUpDYf7GcLwU=
+32KstLuHjTWtyA+ttxPuSBh8dBOzgXP0
+R0BKWexlhKi+zOtc5Fwah4MEakZ0IrV8
+Nem2om6StDc0cxRxSBtSRhh8dBOzgXP0
+o5t4VBdu69n8Oz82iy9RTYMEakZ0IrV8
+fxfJ6RoMGI+4ix4oiZX2k6OtthW9wiK6UpDYf7GcLwU=
+jI5QtUCYYAgsKsPfHh1azcWAX6LVNdgPGHx0E7OBc/Q=
+tGgdDEAjRMvtRWCoq0Oalhh8dBOzgXP0
+b214gJJ6rf9H4CQlYSiaJdeTR/XZs3VK9wsK+2rSHPk=
+fO4QvyH7UNT7sR8MeJwcX2CaWtEhOWcx
+0e9o0KttUaHTGP2eo1YQfib/KxfYdxS6
+PGKr6QvO2ej4Vsqryo5tyMY5DkwsDicsSmARnfpRl/s=
+V0tDiVFWaYY4wif77e5MshkRZaY/U9MJaW/3PQhnPR4=
+LnMBad+fmKutEQr5FjJ1VaOtthW9wiK6UpDYf7GcLwU=
+ZhrzfKcmdRiPFvNYk0OZIB2An0yhn8nnMHSvDnioeQ8=
+5+/DapC0OAbGzne6S+VAbyb/KxfYdxS6
+xo0fNF/FZipm1cuUmJKtvMY5DkwsDicsSmARnfpRl/s=
+saozIdzc//b3ZuttqK5Pu4MEakZ0IrV8
+kQCKl968VncTUFwMdEoHOKOtthW9wiK6UpDYf7GcLwU=
+GuK8q30Rd+EyvXWOV9YsNR2An0yhn8nnMHSvDnioeQ8=
+wXFrN5AIpzRNXiucgF9Qb8Y5DkwsDicsSmARnfpRl/s=
+lsWkkEK+Ki7WDXdMyxenYaOtthW9wiK6UpDYf7GcLwU=
+axNjrUXgZaVm1cuUmJKtvMY5DkwsDicsSmARnfpRl/s=
+4yYYPZE/G2yekoUW0EwcUteTR/XZs3VK9wsK+2rSHPk=
+AOmoKUmWERWfV1m0CzUCqcY5DkwsDicsSmARnfpRl/s=
+MHDIkxYgbthNXiucgF9Qb8Y5DkwsDicsSmARnfpRl/s=
+W0k5qPxTB6Wj3n/1SNP4kB2An0yhn8nnMHSvDnioeQ8=
+CRfnUfHQHHAQMk+tErpQjyCOlDI1vq4kMHSvDnioeQ8=
+z7t5SfKMCd9FKiHwttsti1KQ2H+xnC8F
+XR33j7h38nVseXKeCCrBqBh8dBOzgXP0
+A320qzeUPAL78UBzNhUFKRh8dBOzgXP0
+KVeilKSy6HfEiw+nRvF8pIMEakZ0IrV8
+JZVeWlWnqfAtbPkZ4QHzHqOtthW9wiK6UpDYf7GcLwU=
+jmpRMchH9XZP5r3MsmwzYaOtthW9wiK6UpDYf7GcLwU=
+5G9I6UEbysVCqqe56B9q16OtthW9wiK6UpDYf7GcLwU=
+nD6fTSt5uKST7HFCueSsYcWAX6LVNdgPGHx0E7OBc/Q=
+FYNhFdNzeaWutrkkUhl/aIMEakZ0IrV8
+NQY9mwurZkNNXiucgF9Qb8Y5DkwsDicsSmARnfpRl/s=
+xQxLinTYaTSdCCSK6wg7+oMEakZ0IrV8
+iWOQV773k//AjgYMsni0VYMEakZ0IrV8
+wNNCqjrujy9r2xEnfCwpzh2An0yhn8nnMHSvDnioeQ8=
+fzIdYIZg41dpndkbpI/j79kkrh6n8/H/gwRqRnQitXw=
+3DPu0cSTVVhNXiucgF9Qb8Y5DkwsDicsSmARnfpRl/s=
+b30B3PDWMR/VU14/tiowI1KQ2H+xnC8F
+fZGN2fo5mIi0wkBtAWeSaoMEakZ0IrV8
+fzIRmGqe+BjwvThTNBgJK5dkzcPpM0pSUpDYf7GcLwU=
++46rNRzkPK1F2TtCjyWPXVKQ2H+xnC8F
+nkCG9J64YaQ2QI4TIjBJaBh8dBOzgXP0
+4Y5bS/F5qX6gP8TaFxWYmhh8dBOzgXP0
+EijTSP2IiON5wnewXFhUeIMEakZ0IrV8
+dJEfqjuN2ihh+3jcbo/swRh8dBOzgXP0
+uSFy2OcB2jgHZ4qPGqZvOIMEakZ0IrV8
+jAHK0s8Rjb6C2VfKeWohQpdkzcPpM0pSUpDYf7GcLwU=
+KO7pGmytWvnsjnDzp3PFt4MEakZ0IrV8
+3g2+jKcqWObFEE7safZ3fYMEakZ0IrV8
+xlqtHu+d9v7aHrbJcEhgJRh8dBOzgXP0
+szhbqzDvZLU+eIAVmqYEuoMEakZ0IrV8
+Lt85CacVKRbWO3iuTCXLIoMEakZ0IrV8
+Rjw1F4f0QqVYkQlwVnhyN6OtthW9wiK6UpDYf7GcLwU=
+keCeaoHyP7nnTNBCwWmcGhh8dBOzgXP0
+dkwhJNDluk6HNoUDFzZD74MEakZ0IrV8
+too6iVg0TmAuC9bKqa/sy4MEakZ0IrV8
+GPuQUT+rE8DZbmhnJVX52RkRZaY/U9MJaW/3PQhnPR4=
+He3loJpb80BF2TtCjyWPXVKQ2H+xnC8F
+zeoGqUJo3TMUrAGgjSIHl6OtthW9wiK6UpDYf7GcLwU=
+Q0vzJKIVyQrf1f4BmONUt6OtthW9wiK6UpDYf7GcLwU=
+QdZjIvCLI0MqWaeElU15ypdkzcPpM0pSUpDYf7GcLwU=
+sFKDI4oo3x34Vsqryo5tyMY5DkwsDicsSmARnfpRl/s=
+gGiNkCwWYE/y4jFmiynwN5dkzcPpM0pSUpDYf7GcLwU=
+tnIenaVZgSg1aRPPSnB+UsY5DkwsDicsSmARnfpRl/s=
+Qm7oXyQT0VKOvqVfCNLOER2An0yhn8nnMHSvDnioeQ8=
+DfbiQc3FjNSfV1m0CzUCqcY5DkwsDicsSmARnfpRl/s=
+6HHMxcIViBA1aRPPSnB+UsY5DkwsDicsSmARnfpRl/s=
+oJpaxhx4LFYVSTgPnkj7LJdkzcPpM0pSUpDYf7GcLwU=
+wKrjKNtNHKl7tDlQu4FE8B2An0yhn8nnMHSvDnioeQ8=
+jRs6uH5bcXWRJZetKGfVX9eTR/XZs3VK9wsK+2rSHPk=
+sGu1vnbYpo0mxPDNnSAAIBh8dBOzgXP0
+QN187PuAEjn8vDwuFZfo2ZdkzcPpM0pSUpDYf7GcLwU=
+Jdze9NUgiNEkvd/hxQfqrZdkzcPpM0pSUpDYf7GcLwU=
+WsWCpln2mTXWLQOWJYxFjRkRZaY/U9MJaW/3PQhnPR4=
+dCzxNGa4961kGJQHy79+3MWAX6LVNdgPGHx0E7OBc/Q=
+VCKMbhoLs/lXeT3S3+RTbRkRZaY/U9MJaW/3PQhnPR4=
+9mDyhDBKIrG2DxSyM5ceQyCOlDI1vq4kMHSvDnioeQ8=
+XOuLut56ciG2DxSyM5ceQyCOlDI1vq4kMHSvDnioeQ8=
+zeLZlL+XifE4ga1aDE80gteTR/XZs3VK9wsK+2rSHPk=
+6ksdkkgr0JZex925X9CvAyCOlDI1vq4kMHSvDnioeQ8=
+raOe6pdfsMZm1cuUmJKtvMY5DkwsDicsSmARnfpRl/s=
+r+l2cStew1CEneb6erNr6CCOlDI1vq4kMHSvDnioeQ8=
+xR/VtpKsxdVxVImAwcpxIRkRZaY/U9MJaW/3PQhnPR4=
+gLZQkEEnWbkqWaeElU15ypdkzcPpM0pSUpDYf7GcLwU=
++PMx0RkserbIxJr44Kg9S6OtthW9wiK6UpDYf7GcLwU=
+OvBLGYjamyFQcXKnr7ifmNeTR/XZs3VK9wsK+2rSHPk=
+WUwQe9JgHPj9gcurp44+L8WAX6LVNdgPGHx0E7OBc/Q=
+LChKm/jG64JxVImAwcpxIRkRZaY/U9MJaW/3PQhnPR4=
+1GlacRGfvG8TfbkFXURMqteTR/XZs3VK9wsK+2rSHPk=
+fLuapIr5dGX8vDwuFZfo2ZdkzcPpM0pSUpDYf7GcLwU=
+i1eF0Sx9Xh93clC2fphCksWAX6LVNdgPGHx0E7OBc/Q=
+hRaVyFnOjRNgoUBhEqfoORh8dBOzgXP0
+A6ci44/J07FQqLczy7Zd4R2An0yhn8nnMHSvDnioeQ8=
+lL6bIUXSOYaZ3Og/a67uDJdkzcPpM0pSUpDYf7GcLwU=
+vZLXuKxY03Vex925X9CvAyCOlDI1vq4kMHSvDnioeQ8=
+jpsjeU+KsxZaeztfliRTaRh8dBOzgXP0
+bA5WWs7Qg7oiNpDDEibprNeTR/XZs3VK9wsK+2rSHPk=
+p3EuzoI5DhcxGxdAAgoKm4MEakZ0IrV8
++IMGmmjYDoW/5uPBHaxTJCb/KxfYdxS6
+LQUFUHjnr7UttVHlF3HFoYMEakZ0IrV8
+/Mm8mCa2HlzKu6ryUYTVdoMEakZ0IrV8
+JWcUfmJpGsds+tE269ScU4MEakZ0IrV8
+nP1oCbpGVLv+6KDrJpNNM2TgEgmQimDg
+Yez1ERbxQeamiI3+sMo70IMEakZ0IrV8
+5LkHFbt8yoq/5uPBHaxTJCb/KxfYdxS6
+73Tswbd3YgKutrkkUhl/aIMEakZ0IrV8
+8l6mqwfmk+xBcTLWzKa+voMEakZ0IrV8
+am/8tXL10PqeL1iPrOCbVBh8dBOzgXP0
+bUWe25D0HypdyzHXGGGs8xh8dBOzgXP0
+s+WJENYjmlXxbIQot5MRj8Y5DkwsDicsSmARnfpRl/s=
+tFu0h5Rte4jR2YjYyiilDcWAX6LVNdgPGHx0E7OBc/Q=
+cbnjyj3XVJE7803jm/yXbiCOlDI1vq4kMHSvDnioeQ8=
+3R8sNENbI57asvejoa6HcBh8dBOzgXP0
+8qjvJhATBfEOnS2dCbQqt5dkzcPpM0pSUpDYf7GcLwU=
+kQYvGCYGG30l18oDvxWrSCb/KxfYdxS6
+LLXJ4Gf1sja+1wWbigsLCB2An0yhn8nnMHSvDnioeQ8=
+unke1pTFk0iRwOknXSjgtRh8dBOzgXP0
+k6FmLcYl5bPBxzYNxsK2P4MEakZ0IrV8
+Crr0UkO3MIjjKKKTXK8RniCOlDI1vq4kMHSvDnioeQ8=
+S+lZ/TuxeJz/CqshHti1ehkRZaY/U9MJaW/3PQhnPR4=
+34uUjROpFWxex925X9CvAyCOlDI1vq4kMHSvDnioeQ8=
+FgjMaICJfZEmhdN5xe9ePZdkzcPpM0pSUpDYf7GcLwU=
+4nr+8jIhGeAB7KuaDDIO1h2An0yhn8nnMHSvDnioeQ8=
+qjo6QStEMcWjCA0mZTXe/BkRZaY/U9MJaW/3PQhnPR4=
+w28xlbBhJb+qknOoQbyhkKOtthW9wiK6UpDYf7GcLwU=
+OAfiPmGWCWmy0O3xuiPyBJdkzcPpM0pSUpDYf7GcLwU=
+p65X7IfJ60X0FAzewXMZLZdkzcPpM0pSUpDYf7GcLwU=
+Ux2jmAezWlymiczS51AAkB2An0yhn8nnMHSvDnioeQ8=
+HTNums8nF2k+o1XI7wFy6MWAX6LVNdgPGHx0E7OBc/Q=
+5BdhD8ALRTjYdo0YyFSUzteTR/XZs3VK9wsK+2rSHPk=
+BR2fTQVfTic2Ygj2xVdZclKQ2H+xnC8F
+Y72NZ665aWtIDMkTJ7H4VBh8dBOzgXP0
+cTrWqFl05U1+/NxwjEIRQ4MEakZ0IrV8
++gmt5JsGII1n5hfF+sVT7xh8dBOzgXP0
+9CB7Y38Iruc7+640anOZlSb/KxfYdxS6
+Kjriis2eMzzBciCaqmLN54MEakZ0IrV8
+uKx+/aC8O5iSfOjaarKwDyb/KxfYdxS6
+lknc/1UHONkFH9riPu68rx2An0yhn8nnMHSvDnioeQ8=
+jsMAyl92GAj7RIFjH5BfQZdkzcPpM0pSUpDYf7GcLwU=
+nnKGp+irlWm+dX/yNciHJhh8dBOzgXP0
+j1jXZjExGI29NB9hNSRILBh8dBOzgXP0
+BATpDi4lLfGIDgQg/Fvt3Rh8dBOzgXP0
+k/dRUuexklP8Oz82iy9RTYMEakZ0IrV8
+4VjrLD4FWL07+640anOZlSb/KxfYdxS6
+Ovwx7OFKrM4kwAaC1fb8pRh8dBOzgXP0
+re9PQmMzUqkgvwipfvcNZRh8dBOzgXP0
+JEt7OjmS6+zsk0UrmZ9Ha4MEakZ0IrV8
+85C3w2lkbXnTtNdCIEz+SIMEakZ0IrV8
+XSmroEw9FS03lO+T+coNWoMEakZ0IrV8
+DPGNCfdoBE5v35rsf16PZoMEakZ0IrV8
+Bc16H0Z/CwucGp+BC4pZG5dkzcPpM0pSUpDYf7GcLwU=
+8LAKWJolIS9rH63ZvpfOXZdkzcPpM0pSUpDYf7GcLwU=
+v99ds9+lWDNKNwQ9DS6xKoMEakZ0IrV8
+yz5mSnANrQSpmYlND1T08Bh8dBOzgXP0
++QotMI0XlGMHLJ1H+9SaVyCOlDI1vq4kMHSvDnioeQ8=
+A137zV+G8sroVMYmXl4Mi5dkzcPpM0pSUpDYf7GcLwU=
+lgdzyxxqvyG30z/h++1MrZdkzcPpM0pSUpDYf7GcLwU=
+27k8UPPlunrsQtdwNvzkAB2An0yhn8nnMHSvDnioeQ8=
+xFhzXpymT0LWLQOWJYxFjRkRZaY/U9MJaW/3PQhnPR4=
+cr6vwEFWQXGidcSUYpMSYMWAX6LVNdgPGHx0E7OBc/Q=
+v3eFXjALU5Bex925X9CvAyCOlDI1vq4kMHSvDnioeQ8=
+dqjssxu/jdkvmauKEvAaY8WAX6LVNdgPGHx0E7OBc/Q=
+WpPwd6TTUGHUcqTseE17+KOtthW9wiK6UpDYf7GcLwU=
+x49OpYaGFoNEpBEygT7H6qOtthW9wiK6UpDYf7GcLwU=
+SnFAvZNKdwY9UzAj9Xt34aOtthW9wiK6UpDYf7GcLwU=
+CJR4+H1OO4etyA+ttxPuSBh8dBOzgXP0
+EN2z4UXNGl0B2JImnC+Hl9eTR/XZs3VK9wsK+2rSHPk=
+xm4HmVU2cgwXESDttwlnjSCOlDI1vq4kMHSvDnioeQ8=
+RDZl49UFK9ABJBHzh/mfgZdkzcPpM0pSUpDYf7GcLwU=
+9d8P4DbtI0UkjpEAne6RAKOtthW9wiK6UpDYf7GcLwU=
+CRd2E1ewdnnWLQOWJYxFjRkRZaY/U9MJaW/3PQhnPR4=
+dLBRMlMKPCcp6R/9jooRm6OtthW9wiK6UpDYf7GcLwU=
+uRxDHPZmfczJPsskCXgQ0IMEakZ0IrV8
++szoJVJk1mzFMy9XEaJfzCb/KxfYdxS6
+dZvNsvXrBKGAiHc+YESedMY5DkwsDicsSmARnfpRl/s=
+dwXvhW7qqik0r9vQ/94VZKOtthW9wiK6UpDYf7GcLwU=
+PEwzODYeESvWLQOWJYxFjRkRZaY/U9MJaW/3PQhnPR4=
+lFI/Il9mQLTmE9DvkqV+vYMEakZ0IrV8
+xYD0BTHv+Rf/Hxu1OzY2P9eTR/XZs3VK9wsK+2rSHPk=
+lE5e47O0eNySfOjaarKwDyb/KxfYdxS6
+VbSVFqXmT6aRPqwAptcVSMY5DkwsDicsSmARnfpRl/s=
+mtpgBJ5Os0I5zUkbnLOgWIMEakZ0IrV8
+EMdo3vKWNVxz0/SFIgYbVVKQ2H+xnC8F
+mMkl88PFcehgIP7YuyNph4MEakZ0IrV8
+/qjXnd6tWuQnqYRJMZm8H4MEakZ0IrV8
+KPrD75PhOfwl18oDvxWrSCb/KxfYdxS6
+3sq8FTWCQ068Z/rQSVVCiIMEakZ0IrV8
+/Aqv/sG2LBiWgznSh+iLhtwlBhK2CH9tMHSvDnioeQ8=
+gJYgWFwANLoye3UgOZx3YBh8dBOzgXP0
+PgM9Huc5hWsAIv6jblFCbcWAX6LVNdgPGHx0E7OBc/Q=
+DTW4YQVTpzkhQHWoZSWkGMWAX6LVNdgPGHx0E7OBc/Q=
+CqKXTAJUghfiFx9NAB+QUxh8dBOzgXP0
+9aQb1mSb1rtmxA3pXGemOBkRZaY/U9MJaW/3PQhnPR4=
+M1c424hvhlqD8eNfQOzEVMWAX6LVNdgPGHx0E7OBc/Q=
+MFqn2Ts+2PxgrFsNX2XR69eTR/XZs3VK9wsK+2rSHPk=
+H2CmnsRTaJJQls/CEvTHydeTR/XZs3VK9wsK+2rSHPk=
+CpEbbDTHSVn/CqshHti1ehkRZaY/U9MJaW/3PQhnPR4=
+8S1Vq3o77rvzrdpn+f5OWMWAX6LVNdgPGHx0E7OBc/Q=
+promyYCf2xnAiwXfJ1CCuIMEakZ0IrV8
+a8n2gh4DzxTGzne6S+VAbyb/KxfYdxS6
+UnvS/Ju3I/gXGPhbCd5TE8WAX6LVNdgPGHx0E7OBc/Q=
+GTxF2VIQGQeabwesfUX3QsWAX6LVNdgPGHx0E7OBc/Q=
+q3iZCh5/w9/m+8SDb1QGbMWAX6LVNdgPGHx0E7OBc/Q=
+rivPGeOq1kVn8Cl7DNPnfpdkzcPpM0pSUpDYf7GcLwU=
+Pc1kWCpPeeJo67I3dC4aAJdkzcPpM0pSUpDYf7GcLwU=
+7h0Fnz5v+95ON+qbG7arZZdkzcPpM0pSUpDYf7GcLwU=
+Houc0VCoGXYy1XmB8BCeJ8WAX6LVNdgPGHx0E7OBc/Q=
+1Z8Am5tt6CdyP6Qn2DCpIcWAX6LVNdgPGHx0E7OBc/Q=
+FVxKh9fJOIAHScCpRFo0IR2An0yhn8nnMHSvDnioeQ8=
+dRNd+r6qEbZWcLGKFAhHV5dkzcPpM0pSUpDYf7GcLwU=
+PJ0BQd2W8tNLEZdp6egwu8Y5DkwsDicsSmARnfpRl/s=
+cl57lapWXM74Vsqryo5tyMY5DkwsDicsSmARnfpRl/s=
+Ipfu1UCaOjRFKiHwttsti1KQ2H+xnC8F
+JTPTDc5nGVT8vDwuFZfo2ZdkzcPpM0pSUpDYf7GcLwU=
+7mQJ0kRJhTPMZVa9eXN2PqOtthW9wiK6UpDYf7GcLwU=
+DIuBiKURTLABJBHzh/mfgZdkzcPpM0pSUpDYf7GcLwU=
+cD7DDlDZSIL/UIxFuvEKEcWAX6LVNdgPGHx0E7OBc/Q=
+qm5Z0OqWI3hex925X9CvAyCOlDI1vq4kMHSvDnioeQ8=
+PdvYvOtKOvuRh8Hu5xnz2pdkzcPpM0pSUpDYf7GcLwU=
+uutDS6WaDahTjRBTfKsty1KQ2H+xnC8F
+ULSJLS1qAWoZ32H6X7NNZx2An0yhn8nnMHSvDnioeQ8=
+V+eZVR81gU8nRbvWH9bE9h2An0yhn8nnMHSvDnioeQ8=
+cC2Qql0ACOB0HjSFPR43MoMEakZ0IrV8
+54vALJTBZvr8V9bm6Ooyy9eTR/XZs3VK9wsK+2rSHPk=
+Mf4pBvzFyuOf2dzMPCXVyBh8dBOzgXP0
+veWV+dwdZ/dsnQ9ow8rxmoMEakZ0IrV8
+jggCbYWeWJfb42D2b8mjtYMEakZ0IrV8
+Jns9zQioaZeeTVCLXRXsAKOtthW9wiK6UpDYf7GcLwU=
+ro0/TXuaAxjElV/Mnhvw+NeTR/XZs3VK9wsK+2rSHPk=
+R2V9cgv/pqo3wOkC9+0HINeTR/XZs3VK9wsK+2rSHPk=
+iNlze4E4/jpvKQhlpA5plJdkzcPpM0pSUpDYf7GcLwU=
+yT4TSjQKMeEikfmChjmepsWAX6LVNdgPGHx0E7OBc/Q=
+HdZ31gzQF9c7OuXnwdU6cxkRZaY/U9MJaW/3PQhnPR4=
+NVzrmXRZsbLHhHCapeGwIJdkzcPpM0pSUpDYf7GcLwU=
+uyOinz2/J1LJKqbLImLj78WAX6LVNdgPGHx0E7OBc/Q=
+7XNdhyWh1GNuf007IkcH75dkzcPpM0pSUpDYf7GcLwU=
+NdfEzAeaK0pJuFZCZMhG7BkRZaY/U9MJaW/3PQhnPR4=
+Hci5nGIm8FD/rnqmYXghPcWAX6LVNdgPGHx0E7OBc/Q=
++s7io0k4FyYBJBHzh/mfgZdkzcPpM0pSUpDYf7GcLwU=
+qleeHbSGRZByYm1ZSCssTteTR/XZs3VK9wsK+2rSHPk=
+7krlETqOp60vjLhIuq6sgD0okq5DXPoQ
+G9eCM06xA5VaGyDoRHUsdsWAX6LVNdgPGHx0E7OBc/Q=
+wD1JbNSf726PouNM8CbR15dkzcPpM0pSUpDYf7GcLwU=
+U1FNRgoxCgxMsQgeX0FwVpdkzcPpM0pSUpDYf7GcLwU=
+b5rlHGSdN5IAdZcia36pjsWAX6LVNdgPGHx0E7OBc/Q=
++br1L66mZkO9XvSJdL9MyteTR/XZs3VK9wsK+2rSHPk=
+PoHWaBvBmZNQTN9mSYvDJJdkzcPpM0pSUpDYf7GcLwU=
+UzTSoCUeqm6fyPuEyzS5ZNeTR/XZs3VK9wsK+2rSHPk=
+Cn/QlnjOGoJgvWE3q1auqMWAX6LVNdgPGHx0E7OBc/Q=
+o88BkQpEMUd7yoYa02wYnsWAX6LVNdgPGHx0E7OBc/Q=
+ErgQxb3CVz9AfHPdI01wN6qHdeHVfA/zJv8rF9h3FLo=
+Qsv5maA/dF3Z8QIPCkHhO5dkzcPpM0pSUpDYf7GcLwU=
+79Lg5CUKDmo1aRPPSnB+UsY5DkwsDicsSmARnfpRl/s=
+ZtLkBkMZ0INxoX1YBnywpqOtthW9wiK6UpDYf7GcLwU=
+mQ3q7TokPuEZ+T2p6IwG+sWAX6LVNdgPGHx0E7OBc/Q=
+ucjlA/Hm3WY75YXEVqChw8WAX6LVNdgPGHx0E7OBc/Q=
+y4E47bkD6PRNwtcmXV5vlsWAX6LVNdgPGHx0E7OBc/Q=
+0eiySVjpJZaRkc/RzaYxuteTR/XZs3VK9wsK+2rSHPk=
+zk/hzPkjAbywAElBDLCFxMY5DkwsDicsSmARnfpRl/s=
+sYEV1UAWY9xKl+n5U/v6kRh8dBOzgXP0
+L9bmOzgk+WfZWTXWrY+kZsY5DkwsDicsSmARnfpRl/s=
+WfVD+H52M/R7o4odWO++N/cLCvtq0hz5
+hiYqvtKHjHlrebaRdc+sfiCOlDI1vq4kMHSvDnioeQ8=
+ySLtgXCj++7wx4pyZK17msWAX6LVNdgPGHx0E7OBc/Q=
+Nw8gqWSHqFuAiHc+YESedMY5DkwsDicsSmARnfpRl/s=
+wU1WlNtiAiV+7AYbTNYw4MWAX6LVNdgPGHx0E7OBc/Q=
+vYqBgWqbd6wwso41jtrsKcWAX6LVNdgPGHx0E7OBc/Q=
+gjVSL91rc/ntDKREquMk/CCOlDI1vq4kMHSvDnioeQ8=
++tmQ/uqREgNXeT3S3+RTbRkRZaY/U9MJaW/3PQhnPR4=
+PibuOrUQ7CKGI6KxAN5lc8WAX6LVNdgPGHx0E7OBc/Q=
+Mddit7e9ibzRuQVwPidg/cWAX6LVNdgPGHx0E7OBc/Q=
+h5FEpOVRAKvxbIQot5MRj8Y5DkwsDicsSmARnfpRl/s=
+OoGr8CqMd+r7RIFjH5BfQZdkzcPpM0pSUpDYf7GcLwU=
+ZKxms5FCA30Bk6Fegii9mR2An0yhn8nnMHSvDnioeQ8=
+GNRwBzQ1Jf+y0O3xuiPyBJdkzcPpM0pSUpDYf7GcLwU=
+z9yWaFqq8NqpYttBxY4WySCOlDI1vq4kMHSvDnioeQ8=
+T2Ik/5URWdf8V9bm6Ooyy9eTR/XZs3VK9wsK+2rSHPk=
+XXRZ/77uf11kJAXZn2d3zaqHdeHVfA/zJv8rF9h3FLo=
+TbMBgbZMeMeCzGKd8LXRhh2An0yhn8nnMHSvDnioeQ8=
+IVGUDAcnZK9eZwVzMJT18cWAX6LVNdgPGHx0E7OBc/Q=
+TrBnQxslfgABJBHzh/mfgZdkzcPpM0pSUpDYf7GcLwU=
+JskPCaWlqH0AdZcia36pjsWAX6LVNdgPGHx0E7OBc/Q=
+nAAyT/GpUcSmZrh4182cJJdkzcPpM0pSUpDYf7GcLwU=
+RpTMlS4Fwr1w1w5o5HHGjNeTR/XZs3VK9wsK+2rSHPk=
+3mE30tIvwTgm7xT0wJidLteTR/XZs3VK9wsK+2rSHPk=
+MyQjwXfXD6Xe6qbgYozgjdeTR/XZs3VK9wsK+2rSHPk=
+s9M7XS+rLVjFQKB7O/PJVCCOlDI1vq4kMHSvDnioeQ8=
+/GVTwYSH2SIiQ0OReIiET2CaWtEhOWcx
+id/fPIwrHufWLQOWJYxFjRkRZaY/U9MJaW/3PQhnPR4=
+qZByg6Lqc+b/Hxu1OzY2P9eTR/XZs3VK9wsK+2rSHPk=
+Z285T8ObHXPUK2pdUDEVwU+5TjAW0UK0gwRqRnQitXw=
+lDSuTjIrpvOwAElBDLCFxMY5DkwsDicsSmARnfpRl/s=
+iZVXFvOtRtUfASsrC8SHW9eTR/XZs3VK9wsK+2rSHPk=
+c+dCNEkQf0SEKB4HNpwOUZdkzcPpM0pSUpDYf7GcLwU=
+DAUTwVhtYeyfV1m0CzUCqcY5DkwsDicsSmARnfpRl/s=
+KWSH/hpKWpBUFs54FTOaBiCOlDI1vq4kMHSvDnioeQ8=
+nQta+2/zegZI8kgWKt2ugaOtthW9wiK6UpDYf7GcLwU=
+gxjC7V1sACVjsboY6LVle5dkzcPpM0pSUpDYf7GcLwU=
+udZI8wSG5BIBJBHzh/mfgZdkzcPpM0pSUpDYf7GcLwU=
+b3g/g8g3CKcmTMw6+cFe2MWAX6LVNdgPGHx0E7OBc/Q=
+CnJ/iIs1rUDm4iPHM0n2byCOlDI1vq4kMHSvDnioeQ8=
+Eatv52yqxh8X6+SikxqoQcY5DkwsDicsSmARnfpRl/s=
+gEpZqLyf6Ggkvd/hxQfqrZdkzcPpM0pSUpDYf7GcLwU=
+pT+XmluPMFP8vDwuFZfo2ZdkzcPpM0pSUpDYf7GcLwU=
+JkS/1c5zqMDWfyli4rRcqNeTR/XZs3VK9wsK+2rSHPk=
+R5WXzA1/tPSq4/AgJNI0m5dkzcPpM0pSUpDYf7GcLwU=
+4RFXvd6YmGsq3WV1a+i5CteTR/XZs3VK9wsK+2rSHPk=
+RjeCaXmDcGvuvqZdEK+q/sWAX6LVNdgPGHx0E7OBc/Q=
+Wro0kuJkLAmRh8Hu5xnz2qOtthW9wiK6UpDYf7GcLwU=
+sGdIjpxcpF+7wqHkTIRxghh8dBOzgXP0
+Np/XRe7jhiUPUKWUFMdfu8WAX6LVNdgPGHx0E7OBc/Q=
+BnIOAeHnAqUnX3KKbA5juZdkzcPpM0pSUpDYf7GcLwU=
+NFyZpMW6G7lqF4wvcoOiEpdkzcPpM0pSUpDYf7GcLwU=
+P6gGMNQrCF0+/mUpmgrzM8WAX6LVNdgPGHx0E7OBc/Q=
+/CCSf2XKOmwBY7C7uLmJQyCOlDI1vq4kMHSvDnioeQ8=
+PeATEvxbIPEyResgrmUIKMWAX6LVNdgPGHx0E7OBc/Q=
+3/KaKYe/uFepvXk7rAC36qOtthW9wiK6UpDYf7GcLwU=
+koRxEeiub/efV1m0CzUCqcY5DkwsDicsSmARnfpRl/s=
+ncrtOGRy1DRZMMbwkriszJdkzcPpM0pSUpDYf7GcLwU=
+jgBsxlsCNsEmZbmgnl4inRh8dBOzgXP0
+4Onwgi1RC+XvtjRWuPZHv6OtthW9wiK6UpDYf7GcLwU=
+tlM09cIcyDlvIKTSTmDUg6OtthW9wiK6UpDYf7GcLwU=
+pZ0sQHS7H/M/PrLXpUlI6qOtthW9wiK6UpDYf7GcLwU=
+W5Ce+rf8QEVNXiucgF9Qb8Y5DkwsDicsSmARnfpRl/s=
+vyWyp/5/7es+tOjElU85kMWAX6LVNdgPGHx0E7OBc/Q=
+xCbyEX4yIxkqWaeElU15ypdkzcPpM0pSUpDYf7GcLwU=
+8+2C7IKsc4JRT6Ca/eCpzsWAX6LVNdgPGHx0E7OBc/Q=
+gYoVKQpT9Kway//XQnaHm6OtthW9wiK6UpDYf7GcLwU=
++uSC9DCwHDLZbmhnJVX52RkRZaY/U9MJaW/3PQhnPR4=
+YrbEzaai8aMwW011FvoFfsWAX6LVNdgPGHx0E7OBc/Q=
+KcuDORUG3SyHcHBtdNBSqxkRZaY/U9MJaW/3PQhnPR4=
+/DHYbgVWHbcqWaeElU15ypdkzcPpM0pSUpDYf7GcLwU=
+SHuBeCeq5Rc1aRPPSnB+UsY5DkwsDicsSmARnfpRl/s=
+AWwrb+vxtIo1aRPPSnB+UsY5DkwsDicsSmARnfpRl/s=
+BGWz5zIXr5FWcLGKFAhHV5dkzcPpM0pSUpDYf7GcLwU=
+0aMpxo3ShoRm1cuUmJKtvMY5DkwsDicsSmARnfpRl/s=
+tTXC7NnySWD7RIFjH5BfQZdkzcPpM0pSUpDYf7GcLwU=
+t3hwllPoKkY5yBh5zkn/6KOtthW9wiK6UpDYf7GcLwU=
+hh8j3bWk6x5ms1SZ9iDXwcWAX6LVNdgPGHx0E7OBc/Q=
+XtY6LZ76Dz//CqshHti1ehkRZaY/U9MJaW/3PQhnPR4=
+Z2aEqflvwabNOxiW/N+/5pdkzcPpM0pSUpDYf7GcLwU=
+G0x9jgNM66N3MpdYJGMpIx2An0yhn8nnMHSvDnioeQ8=
+vG+M8f8RvfkT4Du5zQ0eVR2An0yhn8nnMHSvDnioeQ8=
+w+Yk/ChZoak+cWfjnFY5hhkRZaY/U9MJaW/3PQhnPR4=
+d7/3ZMAVv6cX6+SikxqoQcY5DkwsDicsSmARnfpRl/s=
+XioDMImnztozhdUlSVu59BkRZaY/U9MJaW/3PQhnPR4=
+OH4PF68qqMRcd0Pv+DvZlMWAX6LVNdgPGHx0E7OBc/Q=
+bIbZNt+yyu9IICx65f04CpdkzcPpM0pSUpDYf7GcLwU=
+qJk6aG0SBGQ1aRPPSnB+UsY5DkwsDicsSmARnfpRl/s=
+Q1eIXcX/t4rn7MKSnyfBd6OtthW9wiK6UpDYf7GcLwU=
+o7bY4ZFhHpOPB4uyqg/0LaOtthW9wiK6UpDYf7GcLwU=
+QEDlY0EIH03VU14/tiowI1KQ2H+xnC8F
+mtHkENsw+4i11nd7u1J+mB2An0yhn8nnMHSvDnioeQ8=
+JkVqWmDtItp7LTFKqw4ek6OtthW9wiK6UpDYf7GcLwU=
+y5vfU25mxHLWUCgs2La+QqOtthW9wiK6UpDYf7GcLwU=
+KVv6uruXXdezuOZFqz3FDdeTR/XZs3VK9wsK+2rSHPk=
+HdKROqC9gbn4Vsqryo5tyMY5DkwsDicsSmARnfpRl/s=
+eK6VRfg0P0hyVOIAlhFWFxh8dBOzgXP0
+6mGZloafwFA8gBAue4OStRkRZaY/U9MJaW/3PQhnPR4=
+iKQBMV73pH5CTNPvg7cvTcY5DkwsDicsSmARnfpRl/s=
+4swpKBXNHDnlQcqWXv98WNeTR/XZs3VK9wsK+2rSHPk=
+kL1LjFsFOVQb3BIFiUkIi5dkzcPpM0pSUpDYf7GcLwU=
+GLUHV7uBRY6lUi9deTLwVMWAX6LVNdgPGHx0E7OBc/Q=
+DOkU4LDDh/UzZ4tR7YPyiMWAX6LVNdgPGHx0E7OBc/Q=
+4h/n3CzQk0EqWaeElU15ypdkzcPpM0pSUpDYf7GcLwU=
+XqC3e0ITrpuCKI1BQAxl1SCOlDI1vq4kMHSvDnioeQ8=
+pRO0XMPVqKQmpfxwYE04p9eTR/XZs3VK9wsK+2rSHPk=
+OjRY1HXM+z1r1B96hNGmsKOtthW9wiK6UpDYf7GcLwU=
+hNTj5dYP6GgpQli/oD6eAaOtthW9wiK6UpDYf7GcLwU=
+IVpaSmd17umwAElBDLCFxMY5DkwsDicsSmARnfpRl/s=
+HZzCCoYeqOzIDpMHFDXpTcWAX6LVNdgPGHx0E7OBc/Q=
+gYW05s7cbXEHngdJkood0B2An0yhn8nnMHSvDnioeQ8=
+eX6dwWJVaMBm1cuUmJKtvMY5DkwsDicsSmARnfpRl/s=
+kD6XiOxky4+lUi9deTLwVMWAX6LVNdgPGHx0E7OBc/Q=
+Fn3CKg99Bm5yHmx1jHSyDBkRZaY/U9MJaW/3PQhnPR4=
+8y6+LYb83zpVnmsygPmaI6OtthW9wiK6UpDYf7GcLwU=
+b3NrmWfB0oRNXiucgF9Qb8Y5DkwsDicsSmARnfpRl/s=
+c30ty2K47Yp9V7HH7a8mix2An0yhn8nnMHSvDnioeQ8=
+dp0UNvNRReiYbYRf1nVvfaOtthW9wiK6UpDYf7GcLwU=
+XESmjpa/j13joOSu6lYi8aOtthW9wiK6UpDYf7GcLwU=
+NpHW879/YmH7rv+ayztEd6OtthW9wiK6UpDYf7GcLwU=
+gSsx6VI6aazUsErpmDr7Thh8dBOzgXP0
+9nH77u3/7UlcqkANzIjv0xh8dBOzgXP0
+lIiITirSJTITUFwMdEoHOKOtthW9wiK6UpDYf7GcLwU=
+u4dDw975AEBbQnoE+7hVaqOtthW9wiK6UpDYf7GcLwU=
+8YjWakHF8BpuSEWRQFVEANeTR/XZs3VK9wsK+2rSHPk=
+GO2wunuwBP6P0bJRwF21S6OtthW9wiK6UpDYf7GcLwU=
+Rnt+UDMs1M2hLyOLw9N3acWAX6LVNdgPGHx0E7OBc/Q=
+TNh576fEyHDWLQOWJYxFjRkRZaY/U9MJaW/3PQhnPR4=
+Wcpvoz/cHSBIrySmxlyYjKOtthW9wiK6UpDYf7GcLwU=
+eurDrabRH/wtqFMmGRxxKqOtthW9wiK6UpDYf7GcLwU=
+SNz8notuOeMqWaeElU15ypdkzcPpM0pSUpDYf7GcLwU=
+/SJhPqEfiyHKsms8QTljzCCOlDI1vq4kMHSvDnioeQ8=
++iav2cv7dyBbZyIIG7jyM9eTR/XZs3VK9wsK+2rSHPk=
+7QDiToNHBdvhwzFBfYgVaJdkzcPpM0pSUpDYf7GcLwU=
+V33Rj/sin1yVpn1mzCkw7pdkzcPpM0pSUpDYf7GcLwU=
+/h8HxTq92f05kyaMNadVFB2An0yhn8nnMHSvDnioeQ8=
+01JwpLKNytT/CqshHti1ehkRZaY/U9MJaW/3PQhnPR4=
+8HNCj9e89dGg8Jrpm038ZYMEakZ0IrV8
+xLtfJr6bHLz1XEcithQEdKOtthW9wiK6UpDYf7GcLwU=
+ADH8fRlKBa2jZP+265Fm8BkRZaY/U9MJaW/3PQhnPR4=
+S5r9ehg8hwmqMEfhWQDt5yCOlDI1vq4kMHSvDnioeQ8=
+66sxuMU+HF3w+RbvRp7Hy5dkzcPpM0pSUpDYf7GcLwU=
+e/V2W8XaLZzesYX5FbcaWh2An0yhn8nnMHSvDnioeQ8=
+m+cCCJFzWbD2ZdxSvQC7EsWAX6LVNdgPGHx0E7OBc/Q=
+fzIdYIZg41dEK1aJ14hFtSCOlDI1vq4kMHSvDnioeQ8=
+2HP2Kc9wCe69EncC198aeeZVB7mY8h37aW/3PQhnPR4=
+JBWF7pUD15Dpf/37+XRA5x2An0yhn8nnMHSvDnioeQ8=
++MLWVWV8uiz/CqshHti1ehkRZaY/U9MJaW/3PQhnPR4=
+8jDvhuMI3m329ywIMbfV+aOtthW9wiK6UpDYf7GcLwU=
+9s3cRUx75sbQjEWjb8/VyR2An0yhn8nnMHSvDnioeQ8=
+GMhL8lDkS8iskJRp3v9GeMY5DkwsDicsSmARnfpRl/s=
+TKjhositePFnJhXnWkz1h9eTR/XZs3VK9wsK+2rSHPk=
+9njJj9YuXebyfCLXFkCdfhh8dBOzgXP0
+fhSJTALQpei2DxSyM5ceQyCOlDI1vq4kMHSvDnioeQ8=
+kG68RZPkFXBcEe7N73MVbteTR/XZs3VK9wsK+2rSHPk=
+OFxOWAu5tbO2DxSyM5ceQyCOlDI1vq4kMHSvDnioeQ8=
+fnbCNY2tym5950ynmoF1rJdkzcPpM0pSUpDYf7GcLwU=
+3Te/nvKGDLcQaKsreiJw9CCOlDI1vq4kMHSvDnioeQ8=
+Aul6jSkWg7KxTxFeS1hpQhh8dBOzgXP0
+skRy3KohSH33pAl/v9Xu2cWAX6LVNdgPGHx0E7OBc/Q=
+OOl3oxzwgnOy0O3xuiPyBJdkzcPpM0pSUpDYf7GcLwU=
+QnpWdsNSm4xPKfCb+n1fLcWAX6LVNdgPGHx0E7OBc/Q=
+hXf546brDVFadXYDgsAJ7x2An0yhn8nnMHSvDnioeQ8=
+s4Shv7aydq6X1U0N4zGKCx2An0yhn8nnMHSvDnioeQ8=
+IehX2LlU9Mc8gBAue4OStRkRZaY/U9MJaW/3PQhnPR4=
+noKUvDkE0Ztv+9C3VzVlydeTR/XZs3VK9wsK+2rSHPk=
+OB1CLA6CiukGVu1YRoB9TSCOlDI1vq4kMHSvDnioeQ8=
+b6mcIx5Ng9jOfCqz7BPkQyCOlDI1vq4kMHSvDnioeQ8=
+GoEW/ejxQ288gBAue4OStRkRZaY/U9MJaW/3PQhnPR4=
+tH0QSYwhm12RPqwAptcVSMY5DkwsDicsSmARnfpRl/s=
+z5/GDYH2SEB5gEMVGBETmKOtthW9wiK6UpDYf7GcLwU=
+TTONaIF0eOj+6KDrJpNNM2TgEgmQimDg
+SmGhVYgW4yInyIeqDT55DyCOlDI1vq4kMHSvDnioeQ8=
+xcfYqytJG2+Twp4juMWvM6OtthW9wiK6UpDYf7GcLwU=
+1r/PiLOaDwoX6+SikxqoQcY5DkwsDicsSmARnfpRl/s=
+EKmEwCTw8CWpx0+4nd3UTcWAX6LVNdgPGHx0E7OBc/Q=
+K3rC3ryXSlnEl8q+pkR6FNeTR/XZs3VK9wsK+2rSHPk=
+yzK+Yuf799fwx4pyZK17msWAX6LVNdgPGHx0E7OBc/Q=
+g/Hgt0/Jjjm3VYGDkP8Ot5dkzcPpM0pSUpDYf7GcLwU=
+Atwqo+Tu3Ueqwql/yeDx3MWAX6LVNdgPGHx0E7OBc/Q=
+iOuAOrxcyTdrgXjFVn4oM8WAX6LVNdgPGHx0E7OBc/Q=
+C8mMemdJawhc8oezOyWf+8WAX6LVNdgPGHx0E7OBc/Q=
+Dsgg4sKl941V5sGNHfssKSCOlDI1vq4kMHSvDnioeQ8=
+FR7gvbKWc7s4ga1aDE80gteTR/XZs3VK9wsK+2rSHPk=
+g0C8NkGzea+YKIsAPEcUmNeTR/XZs3VK9wsK+2rSHPk=
+VW5D+k2xaY29RtWk3sezJCCOlDI1vq4kMHSvDnioeQ8=
+/ODghHzeBL29Za9jhpiUjteTR/XZs3VK9wsK+2rSHPk=
+wsOBA4KoSTizuOZFqz3FDdeTR/XZs3VK9wsK+2rSHPk=
+6lpwCr9FwunK3IYDhLkaF8WAX6LVNdgPGHx0E7OBc/Q=
+BNuT2mewF5sBJBHzh/mfgZdkzcPpM0pSUpDYf7GcLwU=
+Qxyf2ZLqZyaLPmyI0ov+MMWAX6LVNdgPGHx0E7OBc/Q=
+oWDvK4BkrvEj/zDfTnDF7GCaWtEhOWcx
+/vhPOMB458j/CqshHti1ehkRZaY/U9MJaW/3PQhnPR4=
+BPMuhEQHX9oRzKbMJo8xS8WAX6LVNdgPGHx0E7OBc/Q=
+rnkIoTWEgFIePyL0b/W/KMWAX6LVNdgPGHx0E7OBc/Q=
++wG9CRcrHj1jsboY6LVle6OtthW9wiK6UpDYf7GcLwU=
+9LZh6B6KWXJLS5w8d5sWeMWAX6LVNdgPGHx0E7OBc/Q=
+FXP8QE2NyiYqRGfLZlV9U8WAX6LVNdgPGHx0E7OBc/Q=
+fGR1aUruk2gExLa1GQth8sWAX6LVNdgPGHx0E7OBc/Q=
+wqq+Z0thtXZex925X9CvAyCOlDI1vq4kMHSvDnioeQ8=
+6FSs1w+frjz5FRCh77OensWAX6LVNdgPGHx0E7OBc/Q=
+XzPnJOBMz/dCTNPvg7cvTcY5DkwsDicsSmARnfpRl/s=
+ozOz+yvfxH5Yy9T9qe/NedeTR/XZs3VK9wsK+2rSHPk=
+LVdJE+8Cs8t/ULiYecGzYZdkzcPpM0pSUpDYf7GcLwU=
+fWBo+MiWaIZjPFVJfjuMaMWAX6LVNdgPGHx0E7OBc/Q=
+X5zGza9d+XT66dV+o0NSIZdkzcPpM0pSUpDYf7GcLwU=
+UodjVCPAfr+wAElBDLCFxMY5DkwsDicsSmARnfpRl/s=
+qgcvFmJtWk/4Vsqryo5tyMY5DkwsDicsSmARnfpRl/s=
+7JUszTiZrBE4wif77e5MshkRZaY/U9MJaW/3PQhnPR4=
+hrsDmo1TAHItmO4KHNWldSCOlDI1vq4kMHSvDnioeQ8=
+3+gQwX7OBLyqwql/yeDx3MWAX6LVNdgPGHx0E7OBc/Q=
+MloFpoN0JD62SPDyKy/5AyCOlDI1vq4kMHSvDnioeQ8=
+mqhmM7xJx7Gy0O3xuiPyBJdkzcPpM0pSUpDYf7GcLwU=
++ykMwym9S2nag9+Lsh57vpdkzcPpM0pSUpDYf7GcLwU=
+cZcSD1ce40p+S8OOqNse+8WAX6LVNdgPGHx0E7OBc/Q=
+w9gOp689frvZWTXWrY+kZsY5DkwsDicsSmARnfpRl/s=
+FB5clMRTzqfnrf2oo3Lk0NeTR/XZs3VK9wsK+2rSHPk=
+64P8ZBpG8uauNU7tBpvQDNeTR/XZs3VK9wsK+2rSHPk=
+bRZNLpk4nbxju3EQf8neUh2An0yhn8nnMHSvDnioeQ8=
+j8oidAXZUQ4EleYWgB/h49eTR/XZs3VK9wsK+2rSHPk=
+WHueRm/w+zQuLIyDFlNkBJdkzcPpM0pSUpDYf7GcLwU=
+zYJ5BMhpcMvrZlH/HWfc48WAX6LVNdgPGHx0E7OBc/Q=
+AVtLW31C8xoqWaeElU15ypdkzcPpM0pSUpDYf7GcLwU=
+5y4fghiFmJtbMSFJXe5a9ZdkzcPpM0pSUpDYf7GcLwU=
+/Kar5pijjzPIcvDI/izKd5dkzcPpM0pSUpDYf7GcLwU=
+L1RYL9NnSN3TyeBNGIJLr9eTR/XZs3VK9wsK+2rSHPk=
+p0RCoowijcQqWaeElU15ypdkzcPpM0pSUpDYf7GcLwU=
+6QcN6oSnAdLnrf2oo3Lk0NeTR/XZs3VK9wsK+2rSHPk=
+1NYTbMR28hY45OA+okEbzdeTR/XZs3VK9wsK+2rSHPk=
+bo5SpPvwj9u+g/+zqFG10MWAX6LVNdgPGHx0E7OBc/Q=

+ 17 - 2
trans/src/main/java/com/lantone/qc/trans/comsis/CommonAnalysisUtil.java

@@ -295,6 +295,21 @@ public class CommonAnalysisUtil {
         return null;
     }
 
+    /**
+     * 宁波中医院抽取文本中的第一个时间
+     *
+     * @param top
+     * @return
+     */
+    public static String NBZYExtractDate(String top) {
+        Pattern p1 = Pattern.compile("[0-9]{4}年[0-9]+月[0-9]+日");
+        Matcher m1 = p1.matcher(top);
+        if (m1.find()) {
+            return m1.group(0);
+        }
+        return null;
+    }
+
     /**
      * 宁海医院抽取文本中的第一个时间
      *
@@ -351,10 +366,10 @@ public class CommonAnalysisUtil {
     public static void processType(Map<String, String> structureMap, String title) {
         if (structureMap.containsKey(title)) {
             String type = structureMap.get(title);
-            String[] types = type.split(" ");
+            String[] types = type.split("\uF06F");
             for (String t : types) {
                 if (t.contains("\uF0FE")) {
-                    structureMap.put(title, t.replace("\uF0FE", ""));
+                    structureMap.put(title, t.substring(t.indexOf("\uF0FE") + 1));
                     break;
                 }
             }

+ 38 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/AnesthesiaRecordDocTrans.java

@@ -0,0 +1,38 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.alibaba.fastjson.JSONObject;
+import com.google.common.collect.Lists;
+import com.lantone.qc.pub.model.doc.AnesthesiaRecordDoc;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.trans.ModelDocTrans;
+import lombok.extern.slf4j.Slf4j;
+
+import java.util.List;
+
+/**
+ * @ClassName: AnesthesiaRecordDocTrans
+ * @Description: 手麻记录解析
+ * @Author songxl
+ * @Date 2021/3/19
+ * @Version 1.0
+ */
+@Slf4j
+public class AnesthesiaRecordDocTrans extends ModelDocTrans {
+    @Override
+    public List<AnesthesiaRecordDoc> extract(MedrecVo medrecVo) {
+        List<AnesthesiaRecordDoc> anesList = Lists.newArrayList();
+        try {
+            //1.获取mrqc medrecVo content数据
+            List<String> anesthesiaList = (List<String>)medrecVo.getContent().get("content");
+            //2.装载到AnesthesiaRecordDoc
+            anesthesiaList.forEach(anesthesiaStr->{
+                AnesthesiaRecordDoc anesthesiaTemp =JSONObject.parseObject
+                        (anesthesiaStr, AnesthesiaRecordDoc.class);
+                anesList.add(anesthesiaTemp);
+            });
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return anesList;
+    }
+}

+ 52 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiADLGradeDocTrans.java

@@ -0,0 +1,52 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.lantone.qc.pub.model.doc.ADLGradeDoc;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.util.FastJsonUtils;
+import com.lantone.qc.trans.ModelDocTrans;
+import com.lantone.qc.trans.comsis.ModelDocGenerate;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiADLGradeHtmlAnalysis;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections.MapUtils;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @ClassName: NingBoZhongYiADLGradeDocTrans
+ * @Description: ADL评分
+ * @Author songxl
+ * @Date 2021/3/9
+ * @Version 1.0
+ */
+@Slf4j
+public class NingBoZhongYiADLGradeDocTrans extends ModelDocTrans {
+    @Override
+    public ADLGradeDoc extract(MedrecVo medrecVo) {
+        ADLGradeDoc adlGradeDoc = null;
+        try {
+            Map<String, Object> contentMap = ((List<Map>) medrecVo.getContent().get("content")).get(0);
+            String content = contentMap.get("xmlText").toString();
+            Map<String, String> structureMap = null;
+            if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+                structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+            } else {
+                String recTitle = contentMap.get("recTitle").toString();
+                String recTypeId = contentMap.get("recTypeId").toString();
+                NingBoZhongYiADLGradeHtmlAnalysis adlGradeHtmlAnalysis = new NingBoZhongYiADLGradeHtmlAnalysis();
+                Map<String, String> sourceMap = adlGradeHtmlAnalysis.analysis(content, recTitle, recTypeId);
+                if (MapUtils.isNotEmpty(sourceMap)) {
+                    structureMap.putAll(sourceMap);
+                }
+            }
+            if (MapUtils.isNotEmpty(structureMap)) {
+                              ModelDocGenerate.beHospitalizedDocGen(structureMap);
+                adlGradeDoc = ModelDocGenerate.adlGradeDocGen(structureMap);
+                adlGradeDoc.setPageData((Map) structureMap);
+            }
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return adlGradeDoc;
+    }
+}

+ 72 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiBeHospitalizedDocTrans.java

@@ -0,0 +1,72 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.google.common.collect.Lists;
+import com.lantone.qc.pub.model.doc.BeHospitalizedDoc;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.util.FastJsonUtils;
+import com.lantone.qc.trans.ModelDocTrans;
+import com.lantone.qc.trans.comsis.ModelDocGenerate;
+import com.lantone.qc.trans.comsis.OrdinaryAssistant;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiBeHospitalizedHtmlAnalysis;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiHtmlAnalysis;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections.MapUtils;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description: 入院记录文档生成
+ * @author: rengb
+ * @time: 2020/3/5 15:47
+ */
+@Slf4j
+public class NingBoZhongYiBeHospitalizedDocTrans extends ModelDocTrans {
+
+    @Override
+    public BeHospitalizedDoc extract(MedrecVo medrecVo) {
+        BeHospitalizedDoc beHospitalizedDoc = null;
+        try {
+            Map<String, Object> contentMap = ((List<Map>) medrecVo.getContent().get("content")).get(0);
+            String content = contentMap.get("xmlText").toString();
+            Map<String, String> structureMap = null;
+            if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+                structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+            } else {
+                String recTitle = contentMap.get("recTitle").toString();
+                String recTypeId = contentMap.get("recTypeId").toString();
+                NingBoZhongYiHtmlAnalysis beiLunHtmlAnalysis = new NingBoZhongYiBeHospitalizedHtmlAnalysis();
+                Map<String, String> sourceMap = beiLunHtmlAnalysis.analysis(content, recTitle, recTypeId);
+                if (MapUtils.isNotEmpty(sourceMap)) {
+                    structureMap = OrdinaryAssistant.mapKeyContrast(sourceMap, keyContrasts);
+                    structureMap.put("记录编号", contentMap.get("recId").toString());
+                    structureMap.put("病历号", contentMap.get("behospitalCode") == null ? null : contentMap.get("behospitalCode").toString());
+                    //初步诊断特殊处理
+                    if (structureMap.containsKey("初步诊断")) {
+                        String initDiag = structureMap.get("初步诊断");
+                        if (initDiag.contains("<img")) {
+                            initDiag = initDiag.split("<img")[0];
+                            structureMap.put("初步诊断", initDiag);
+                        }
+                    }
+                }
+            }
+            if (MapUtils.isNotEmpty(structureMap)) {
+                beHospitalizedDoc = ModelDocGenerate.beHospitalizedDocGen(structureMap);
+                beHospitalizedDoc.setPageData((Map) structureMap);
+            }
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return beHospitalizedDoc;
+    }
+
+    private List<String> keyContrasts = Lists.newArrayList(
+            "家庭地址=住址",
+            "出生地=籍贯",
+            "医生签名=记录医生",
+            "疼痛评估=疼痛",
+            "代诉=主诉"
+    );
+
+}

+ 73 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiClinicBloodEffectDocTrans.java

@@ -0,0 +1,73 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.google.common.collect.Lists;
+import com.lantone.qc.pub.model.doc.ClinicBloodEffectDoc;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.util.FastJsonUtils;
+import com.lantone.qc.trans.ModelDocTrans;
+import com.lantone.qc.trans.comsis.ModelDocGenerate;
+import com.lantone.qc.trans.comsis.OrdinaryAssistant;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiClinicBloodEffectHtmlAnalysis;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiHtmlAnalysis;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections.MapUtils;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @author 王宇
+ * @create 2020-04-30 12:39
+ * @desc 输血后效果评价
+ **/
+@Slf4j
+public class NingBoZhongYiClinicBloodEffectDocTrans extends ModelDocTrans {
+
+    @Override
+    public List<ClinicBloodEffectDoc> extract(MedrecVo medrecVo) {
+        List<ClinicBloodEffectDoc> retList = Lists.newArrayList();
+        List<Map<String, Object>> contentMaps = (List) medrecVo.getContent().get("content");
+        contentMaps.forEach(contentMap -> {
+            try {
+                ClinicBloodEffectDoc clinicBloodEffectDoc = getClinicalBloodDoc(contentMap);
+                if (clinicBloodEffectDoc != null) {
+                    retList.add(clinicBloodEffectDoc);
+                }
+            } catch (Exception e) {
+                log.error(e.getMessage(), e);
+            }
+        });
+        return retList;
+    }
+
+    private ClinicBloodEffectDoc getClinicalBloodDoc(Map<String, Object> contentMap) {
+        String content = contentMap.get("xmlText").toString();
+        Map<String, String> structureMap = null;
+        if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+            structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+        } else {
+            String recTitle = contentMap.get("recTitle").toString();
+            String recTypeId = contentMap.get("recTypeId").toString();
+            NingBoZhongYiHtmlAnalysis beiLunHtmlAnalysis = new NingBoZhongYiClinicBloodEffectHtmlAnalysis();
+            Map<String, String> sourceMap = beiLunHtmlAnalysis.analysis(content, recTitle, recTypeId);
+            if (MapUtils.isNotEmpty(sourceMap)) {
+                structureMap = OrdinaryAssistant.mapKeyContrast(sourceMap, keyContrasts);
+                structureMap.put("记录编号", contentMap.get("recId").toString());
+                structureMap.put("病历号", contentMap.get("behospitalCode") == null ? null : contentMap.get("behospitalCode").toString());
+            }
+        }
+        if (MapUtils.isNotEmpty(structureMap)) {
+            ClinicBloodEffectDoc clinicBloodEffectDoc = ModelDocGenerate.clinicBloodEffectDoc(structureMap);
+            clinicBloodEffectDoc.setPageData((Map) structureMap);
+            return clinicBloodEffectDoc;
+        } else {
+            return null;
+        }
+    }
+
+    private List<String> keyContrasts = Lists.newArrayList(
+            "病历标题=标题",
+            "病情记录=病历内容"
+    );
+
+}

+ 77 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiClinicalBloodDocTrans.java

@@ -0,0 +1,77 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.google.common.collect.Lists;
+import com.lantone.qc.pub.model.doc.ClinicalBloodDoc;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.util.FastJsonUtils;
+import com.lantone.qc.trans.ModelDocTrans;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import com.lantone.qc.trans.comsis.ModelDocGenerate;
+import com.lantone.qc.trans.comsis.OrdinaryAssistant;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiClinicalBloodHtmlAnalysis;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiHtmlAnalysis;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections.MapUtils;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description: 输血/血制品病程记录文档生成
+ * @author: rengb
+ * @time: 2020/3/17 13:21
+ */
+@Slf4j
+public class NingBoZhongYiClinicalBloodDocTrans extends ModelDocTrans {
+
+    @Override
+    public List<ClinicalBloodDoc> extract(MedrecVo medrecVo) {
+        List<ClinicalBloodDoc> retList = Lists.newArrayList();
+        List<Map<String, Object>> contentMaps = (List) medrecVo.getContent().get("content");
+        contentMaps.forEach(contentMap -> {
+            try {
+                ClinicalBloodDoc clinicalBloodDoc = getClinicalBloodDoc(contentMap);
+                if (clinicalBloodDoc != null) {
+                    retList.add(clinicalBloodDoc);
+                }
+            } catch (Exception e) {
+                log.error(e.getMessage(), e);
+            }
+        });
+        return retList;
+    }
+
+    private ClinicalBloodDoc getClinicalBloodDoc(Map<String, Object> contentMap) {
+        String content = contentMap.get("xmlText").toString();
+        Map<String, String> structureMap = null;
+        if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+            structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+        } else {
+            String recTitle = contentMap.get("recTitle").toString();
+            String recTypeId = contentMap.get("recTypeId").toString();
+            NingBoZhongYiHtmlAnalysis beiLunHtmlAnalysis = new NingBoZhongYiClinicalBloodHtmlAnalysis();
+            Map<String, String> sourceMap = beiLunHtmlAnalysis.analysis(content, recTitle, recTypeId);
+            if (MapUtils.isNotEmpty(sourceMap)) {
+                structureMap = OrdinaryAssistant.mapKeyContrast(sourceMap, keyContrasts);
+                structureMap.put("记录编号", contentMap.get("recId").toString());
+                structureMap.put("病历号", contentMap.get("behospitalCode") == null ? null : contentMap.get("behospitalCode").toString());
+            }
+        }
+        if (MapUtils.isNotEmpty(structureMap)) {
+            ClinicalBloodDoc clinicalBloodDoc = ModelDocGenerate.clinicalBloodDocGen(structureMap);
+            clinicalBloodDoc.setText(CommonAnalysisUtil.html2String(content));
+            clinicalBloodDoc.setPageData((Map) structureMap);
+            return clinicalBloodDoc;
+        } else {
+            return null;
+        }
+    }
+
+    private List<String> keyContrasts = Lists.newArrayList(
+            "病历标题=标题",
+            "输注成分=输注种类、血型、数量",
+            "输血过程=输注过程",
+            "病情记录=病历内容"
+    );
+
+}

+ 278 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiConsultationDocTrans.java

@@ -0,0 +1,278 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.google.common.collect.Sets;
+import com.lantone.qc.pub.model.doc.consultation.ConsultationApplicationDoc;
+import com.lantone.qc.pub.model.doc.consultation.ConsultationDoc;
+import com.lantone.qc.pub.model.doc.consultation.ConsultationRecordDoc;
+import com.lantone.qc.pub.model.doc.consultation.ConsultationResultsDoc;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.util.FastJsonUtils;
+import com.lantone.qc.pub.util.ListUtil;
+import com.lantone.qc.pub.util.StringUtil;
+import com.lantone.qc.trans.ModelDocTrans;
+import com.lantone.qc.trans.comsis.ModelDocGenerate;
+import com.lantone.qc.trans.comsis.OrdinaryAssistant;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiConsultationHtmlAnalysis;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiConsultationRecordHtmlAnalysis;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiHtmlAnalysis;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections.MapUtils;
+
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+
+/**
+ * @Description: 会诊文档生成
+ * @author: rengb
+ * @time: 2020/3/17 13:22
+ */
+@Slf4j
+public class NingBoZhongYiConsultationDocTrans extends ModelDocTrans {
+
+    @Override
+    public List<ConsultationDoc> extract(MedrecVo medrecVo) {
+        List<ConsultationDoc> retList = Lists.newArrayList();
+
+        Map<String, List<Object>> contentMap = (Map) medrecVo.getContent().get("content");
+        if (contentMap == null) {
+            return retList;
+        }
+
+        Map<String, ConsultationRecordDoc> consultationRecordDocMap = getConsultationRecordDocMap((List) contentMap.get("会诊记录"));
+        Map<String, ConsultationResultsDoc> consultationResultsDocMap = getConsultationResultsDocMap((List) contentMap.get("会诊结果单"));
+        Map<String, ConsultationApplicationDoc> consultationApplicationDocMap = getConsultationApplicationDocMap((List) contentMap.get("会诊申请单"));
+
+        Set<String> consultationNameSet = Sets.newHashSet();
+        consultationNameSet.addAll(consultationRecordDocMap.keySet());
+        consultationNameSet.addAll(consultationResultsDocMap.keySet());
+        consultationNameSet.addAll(consultationApplicationDocMap.keySet());
+
+        consultationNameSet.forEach(consultationName -> {
+            ConsultationDoc consultationDoc = new ConsultationDoc();
+            consultationDoc.setConsultationName(consultationName);
+            consultationDoc.setConsultationRecordDoc(consultationRecordDocMap.get(consultationName));
+            consultationDoc.setConsultationResultsDoc(consultationResultsDocMap.get(consultationName));
+            consultationDoc.setConsultationApplicationDoc(consultationApplicationDocMap.get(consultationName));
+            retList.add(consultationDoc);
+        });
+
+        return retList;
+    }
+
+
+    /**************************************************会诊记录*********************************************************/
+    private Map<String, ConsultationRecordDoc> getConsultationRecordDocMap(List<Map<String, Object>> contentMaps) {
+        Map<String, ConsultationRecordDoc> retMap = Maps.newHashMap();
+        if (ListUtil.isEmpty(contentMaps)) {
+            return retMap;
+        }
+        int index = 1;
+        String consultationName = null;
+        for (Map<String, Object> contentMap : contentMaps) {
+            if (contentMap.get("xmlText") == null || StringUtil.isBlank(contentMap.get("xmlText").toString())) {
+                continue;
+            }
+            try {
+                ConsultationRecordDoc consultationRecordDoc = getConsultationRecordDoc(contentMap);
+                if (consultationRecordDoc != null) {
+                    consultationName = index + "";
+                    consultationRecordDoc.setConsultationName(consultationName);
+                    retMap.put(consultationName, consultationRecordDoc);
+                    index++;
+                }
+            } catch (Exception e) {
+                log.error(e.getMessage(), e);
+            }
+        }
+        return retMap;
+    }
+
+    private ConsultationRecordDoc getConsultationRecordDoc(Map<String, Object> contentMap) {
+        String content = contentMap.get("xmlText").toString();
+        Map<String, String> structureMap = null;
+        if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+            structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+        } else {
+            String recTitle = contentMap.get("recTitle").toString();
+            String recTypeId = contentMap.get("recTypeId").toString();
+            NingBoZhongYiHtmlAnalysis ningBoZhongYiHtmlAnalysis = new NingBoZhongYiConsultationRecordHtmlAnalysis();
+            Map<String, String> sourceMap = ningBoZhongYiHtmlAnalysis.analysis(content, recTitle, recTypeId);
+            if (MapUtils.isNotEmpty(sourceMap)) {
+                structureMap = OrdinaryAssistant.mapKeyContrast(sourceMap, consultationRecord_keyContrasts);
+                structureMap.put("记录编号", contentMap.get("recId").toString());
+                structureMap.put("病历号", contentMap.get("behospitalCode") == null ? null : contentMap.get("behospitalCode").toString());
+            }
+        }
+        if (MapUtils.isNotEmpty(structureMap)) {
+            ConsultationRecordDoc consultationRecordDoc = ModelDocGenerate.consultationRecordDocGen(structureMap);
+            consultationRecordDoc.setPageData((Map) structureMap);
+            return consultationRecordDoc;
+        } else {
+            return null;
+        }
+    }
+
+    private List<String> consultationRecord_keyContrasts = Lists.newArrayList(
+            "执行情况=会诊情况",
+            "记录日期=会诊申请日期",
+            "签名++++=签名",
+            "病情记录=简要病情",
+            "医师签名=签名"
+    );
+
+
+    /**************************************************会诊结果单*******************************************************/
+    private Map<String, ConsultationResultsDoc> getConsultationResultsDocMap(List<Map<String, Object>> contentMaps) {
+        Map<String, ConsultationResultsDoc> retMap = Maps.newHashMap();
+        if (ListUtil.isEmpty(contentMaps)) {
+            return retMap;
+        }
+        int index = 1;
+        String consultationName = null;
+        for (Map<String, Object> contentMap : contentMaps) {
+            if (contentMap.get("xmlText") == null || StringUtil.isBlank(contentMap.get("xmlText").toString())) {
+                continue;
+            }
+            try {
+                ConsultationResultsDoc consultationResultsDoc = getConsultationResultsDoc(contentMap);
+                if (consultationResultsDoc != null) {
+                    consultationName = index + "";
+                    consultationResultsDoc.setConsultationName(consultationName);
+                    retMap.put(consultationName, consultationResultsDoc);
+                    index++;
+                }
+            } catch (Exception e) {
+                log.error(e.getMessage(), e);
+            }
+        }
+        return retMap;
+    }
+
+    private ConsultationResultsDoc getConsultationResultsDoc(Map<String, Object> contentMap) {
+        String content = contentMap.get("xmlText").toString();
+        Map<String, String> structureMap = null;
+        if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+            structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+        } else {
+            String recTitle = contentMap.get("recTitle").toString();
+            String recTypeId = contentMap.get("recTypeId").toString();
+            NingBoZhongYiHtmlAnalysis ningBoZhongYiHtmlAnalysis = new NingBoZhongYiConsultationHtmlAnalysis();
+            Map<String, String> sourceMap = ningBoZhongYiHtmlAnalysis.analysis(content, recTitle, recTypeId);
+            if (MapUtils.isNotEmpty(sourceMap)) {
+                structureMap = OrdinaryAssistant.mapKeyContrast(sourceMap, consultationResults_pageDataTitles);
+                structureMap.put("记录编号", contentMap.get("recId").toString());
+                structureMap.put("病历号", contentMap.get("behospitalCode") == null ? null : contentMap.get("behospitalCode").toString());
+            }
+        }
+        if (StringUtil.isNotBlank(structureMap.get("会诊科室"))) {
+            structureMap.put("会诊科室", structureMap.get("会诊科室").replaceAll("XXXX", "").trim());
+        }
+        if (MapUtils.isNotEmpty(structureMap)) {
+            ConsultationResultsDoc consultationResultsDoc = ModelDocGenerate.consultationResultsDocGen(structureMap);
+            consultationResultsDoc.setPageData((Map) structureMap);
+            return consultationResultsDoc;
+        } else {
+            return null;
+        }
+    }
+
+    private List<String> consultationResults_pageDataTitles = Lists.newArrayList(
+            "科室=科别",
+            "专业=科别",
+            "申请会诊科别=申请科室",
+            "申请时间=申请日期",
+            "会诊日期=申请日期",
+            //"会诊诊断=当前诊断",
+            "患者病情及诊疗经过、申请会诊的理由及目的=会诊目的",
+            "病情摘要=会诊目的",
+            "出生年月=出生日期",
+            "床位=床号",
+            "外来专家意见=会诊意见",
+            "由受邀医生填写,本次会诊是否必要=由受邀医生填写本次会诊是否必要",
+            "单位=会诊医师所在医疗机构名称",
+            "记录医师"
+    );
+
+
+    /**************************************************会诊申请单*******************************************************/
+    private Map<String, ConsultationApplicationDoc> getConsultationApplicationDocMap(List<Map<String, Object>> contentMaps) {
+        Map<String, ConsultationApplicationDoc> retMap = Maps.newHashMap();
+        if (ListUtil.isEmpty(contentMaps)) {
+            return retMap;
+        }
+        int index = 1;
+        String consultationName = null;
+        for (Map<String, Object> contentMap : contentMaps) {
+            if (contentMap.get("xmlText") == null || StringUtil.isBlank(contentMap.get("xmlText").toString())) {
+                continue;
+            }
+            consultationName = index + "";
+            ConsultationApplicationDoc consultationApplicationDoc = getConsultationApplicationDoc(contentMap);
+            consultationApplicationDoc.setConsultationName(consultationName);
+            retMap.put(consultationName, consultationApplicationDoc);
+            index++;
+        }
+        return retMap;
+    }
+
+    private ConsultationApplicationDoc getConsultationApplicationDoc(Map<String, Object> contentMap) {
+        String content = contentMap.get("xmlText").toString();
+        Map<String, String> structureMap = null;
+        if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+            structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+        } else {
+            String recTitle = contentMap.get("recTitle").toString();
+            String recTypeId = contentMap.get("recTypeId").toString();
+            NingBoZhongYiHtmlAnalysis ningBoZhongYiHtmlAnalysis = new NingBoZhongYiConsultationHtmlAnalysis();
+            Map<String, String> sourceMap = ningBoZhongYiHtmlAnalysis.analysis(content, recTitle, recTypeId);
+            structureMap = OrdinaryAssistant.mapKeyContrast(sourceMap, consultationApplication_keyContrasts);
+            structureMap.put("记录编号", contentMap.get("recId").toString());
+            structureMap.put("病历号", contentMap.get("behospitalCode") == null ? null : contentMap.get("behospitalCode").toString());
+        }
+
+        ConsultationApplicationDoc consultationApplicationDoc = ModelDocGenerate.consultationApplicationDocGen(structureMap);
+        consultationApplicationDoc.setText(content);
+        consultationApplicationDoc.setPageData((Map) structureMap);
+
+        return consultationApplicationDoc;
+    }
+
+    private List<String> consultationApplication_sourceTitles = Lists.newArrayList(
+            "姓名",
+            "性别",
+            "病区",
+            "床号",
+            "病案号",
+            "简要病情及诊疗",
+            "申请理由目的",
+            "受邀科室",
+            "会诊分类",
+            "会诊时间",
+            "会诊地点",
+            "签名"
+    );
+
+    private List<String> consultationApplication_keyContrasts = Lists.newArrayList(
+            "++++姓名=姓名",
+            "申请时间=申请日期",
+            "性别=性别",
+            "++++病区=病区",
+            "床号=",
+            "++++病案号=病案号",
+            "新会诊-简要病情及诊疗=简要病情及诊疗",
+            "新会诊-申请理由目的=会诊目的",
+            "新会诊-受邀科室=受邀科室",
+            "新会诊-会诊分类=会诊分类",
+            "新会诊-会诊时间=会诊时间",
+            "新会诊-会诊地点=会诊地点",
+            "新会诊-接待医生=会诊医师",
+            "新会诊-会诊意见=会诊意见",
+            "新会诊-会诊科室=会诊科室",
+            "签名++++=签名",
+            "++++会诊医师=会诊医师"
+    );
+
+}

+ 36 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiCrisisInfoDocTrans.java

@@ -0,0 +1,36 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.google.common.collect.Lists;
+import com.lantone.qc.pub.model.doc.CrisisInfoDoc;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.util.FastJsonUtils;
+import com.lantone.qc.trans.ModelDocTrans;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description: 危急值结构化信息
+ * @author: rengb
+ * @time: 2020/3/19 19:41
+ */
+public class NingBoZhongYiCrisisInfoDocTrans extends ModelDocTrans {
+
+    @Override
+    public List<CrisisInfoDoc> extract(MedrecVo medrecVo) {
+        List<CrisisInfoDoc> retList = Lists.newArrayList();
+        List<String> contents = (List) medrecVo.getContent().get("content");
+        contents.forEach(content -> {
+            retList.add(getCrisisInfoDoc((Map) FastJsonUtils.getJsonToMap(content)));
+        });
+        return retList;
+    }
+
+    private CrisisInfoDoc getCrisisInfoDoc(Map<String, String> content) {
+        CrisisInfoDoc crisisInfoDoc = new CrisisInfoDoc();
+        crisisInfoDoc.setStructureMap(content);
+        crisisInfoDoc.setPageData((Map) content);
+        return crisisInfoDoc;
+    }
+
+}

+ 72 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiCrisisValueReportDocTrans.java

@@ -0,0 +1,72 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.google.common.collect.Lists;
+import com.lantone.qc.pub.model.doc.CrisisValueReportDoc;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.util.FastJsonUtils;
+import com.lantone.qc.trans.ModelDocTrans;
+import com.lantone.qc.trans.comsis.ModelDocGenerate;
+import com.lantone.qc.trans.comsis.OrdinaryAssistant;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiCrisisValueReportHtmlAnalysis;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiHtmlAnalysis;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections.MapUtils;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description: 危急值记录文档生成
+ * @author: rengb
+ * @time: 2020/3/19 19:41
+ */
+@Slf4j
+public class NingBoZhongYiCrisisValueReportDocTrans extends ModelDocTrans {
+
+    @Override
+    public List<CrisisValueReportDoc> extract(MedrecVo medrecVo) {
+        List<CrisisValueReportDoc> retList = Lists.newArrayList();
+        List<Map<String, Object>> contentMaps = (List) medrecVo.getContent().get("content");
+        contentMaps.forEach(contentMap -> {
+            try {
+                CrisisValueReportDoc crisisValueReportDoc = getCrisisValueReportDoc(contentMap);
+                if (crisisValueReportDoc != null) {
+                    retList.add(crisisValueReportDoc);
+                }
+            } catch (Exception e) {
+                log.error(e.getMessage(), e);
+            }
+        });
+        return retList;
+    }
+
+    private CrisisValueReportDoc getCrisisValueReportDoc(Map<String, Object> contentMap) {
+        String content = contentMap.get("xmlText").toString();
+        Map<String, String> structureMap = null;
+        if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+            structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+        } else {
+            String recTitle = contentMap.get("recTitle").toString();
+            String recTypeId = contentMap.get("recTypeId").toString();
+            NingBoZhongYiHtmlAnalysis ningBoZhongYiHtmlAnalysis = new NingBoZhongYiCrisisValueReportHtmlAnalysis();
+            Map<String, String> sourceMap = ningBoZhongYiHtmlAnalysis.analysis(content, recTitle, recTypeId);
+            if (MapUtils.isNotEmpty(sourceMap)) {
+                structureMap = OrdinaryAssistant.mapKeyContrast(sourceMap, keyContrasts);
+                structureMap.put("记录编号", contentMap.get("recId").toString());
+                structureMap.put("病历号", contentMap.get("behospitalCode") == null ? null : contentMap.get("behospitalCode").toString());
+            }
+        }
+        if (MapUtils.isNotEmpty(structureMap)) {
+            CrisisValueReportDoc crisisValueReportDoc = ModelDocGenerate.crisisValueReportDocGen(structureMap);
+            crisisValueReportDoc.setPageData((Map) structureMap);
+            return crisisValueReportDoc;
+        } else {
+            return null;
+        }
+    }
+
+    private List<String> keyContrasts = Lists.newArrayList(
+            "病情记录=病情分析及处理"
+    );
+
+}

+ 75 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiCriticallyIllNoticeDocTrans.java

@@ -0,0 +1,75 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.google.common.collect.Lists;
+import com.lantone.qc.pub.model.doc.CriticallyIllNoticeDoc;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.util.FastJsonUtils;
+import com.lantone.qc.trans.ModelDocTrans;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import com.lantone.qc.trans.comsis.ModelDocGenerate;
+import com.lantone.qc.trans.comsis.OrdinaryAssistant;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiCriticallyIllNoticeHtmlAnalysis;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiHtmlAnalysis;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections.MapUtils;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description: 病危通知书文档生成
+ * @author: rengb
+ * @time: 2020/3/19 19:41
+ */
+@Slf4j
+public class NingBoZhongYiCriticallyIllNoticeDocTrans extends ModelDocTrans {
+
+    @Override
+    public List<CriticallyIllNoticeDoc> extract(MedrecVo medrecVo) {
+        List<CriticallyIllNoticeDoc> retList = Lists.newArrayList();
+        List<Map<String, Object>> contentMaps = (List) medrecVo.getContent().get("content");
+        contentMaps.forEach(contentMap -> {
+            try {
+                CriticallyIllNoticeDoc criticallyIllNoticeDoc = getCriticallyIllNoticeDoc(contentMap);
+                if (criticallyIllNoticeDoc != null) {
+                    retList.add(criticallyIllNoticeDoc);
+                }
+            } catch (Exception e) {
+                log.error(e.getMessage(), e);
+            }
+        });
+        return retList;
+    }
+
+    private CriticallyIllNoticeDoc getCriticallyIllNoticeDoc(Map<String, Object> contentMap) {
+        String content = contentMap.get("xmlText").toString();
+        Map<String, String> structureMap = null;
+        if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+            structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+        } else {
+            String recTitle = contentMap.get("recTitle").toString();
+            String recTypeId = contentMap.get("recTypeId").toString();
+            NingBoZhongYiHtmlAnalysis ningBoZhongYiHtmlAnalysis = new NingBoZhongYiCriticallyIllNoticeHtmlAnalysis();
+            Map<String, String> sourceMap = ningBoZhongYiHtmlAnalysis.analysis(content, recTitle, recTypeId);
+            if (MapUtils.isNotEmpty(sourceMap)) {
+                structureMap = OrdinaryAssistant.mapKeyContrast(sourceMap, keyContrasts);
+                structureMap.put("记录编号", contentMap.get("recId").toString());
+                structureMap.put("病历号", contentMap.get("behospitalCode") == null ? null : contentMap.get("behospitalCode").toString());
+            }
+        }
+        if (MapUtils.isNotEmpty(structureMap)) {
+            CriticallyIllNoticeDoc criticallyIllNoticeDoc = ModelDocGenerate.criticallyIllNoticeDocGen(structureMap);
+            criticallyIllNoticeDoc.setText(CommonAnalysisUtil.html2String(content));
+            criticallyIllNoticeDoc.setPageData((Map) structureMap);
+            return criticallyIllNoticeDoc;
+        } else {
+            return null;
+        }
+    }
+
+    private List<String> keyContrasts = Lists.newArrayList(
+            "临床诊断=当前诊断",
+            "患方签名=患者签名"
+    );
+
+}

+ 70 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiDeathCaseDiscussDocTrans.java

@@ -0,0 +1,70 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.google.common.collect.Lists;
+import com.lantone.qc.pub.model.doc.DeathCaseDiscussDoc;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.util.FastJsonUtils;
+import com.lantone.qc.trans.ModelDocTrans;
+import com.lantone.qc.trans.comsis.ModelDocGenerate;
+import com.lantone.qc.trans.comsis.OrdinaryAssistant;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiDeathCaseDiscussHtmlAnalysis;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiHtmlAnalysis;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections.MapUtils;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description: 死亡病例讨论记录文档生成
+ * @author: rengb
+ * @time: 2020/3/17 13:22
+ */
+@Slf4j
+public class NingBoZhongYiDeathCaseDiscussDocTrans extends ModelDocTrans {
+
+    @Override
+    public DeathCaseDiscussDoc extract(MedrecVo medrecVo) {
+        DeathCaseDiscussDoc deathCaseDiscussDoc = null;
+        try {
+            Map<String, Object> contentMap = ((List<Map>) medrecVo.getContent().get("content")).get(0);
+            String content = contentMap.get("xmlText").toString();
+            Map<String, String> structureMap = null;
+            if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+                structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+            } else {
+                String recTitle = contentMap.get("recTitle").toString();
+                String recTypeId = contentMap.get("recTypeId").toString();
+                NingBoZhongYiHtmlAnalysis ningBoZhongYiHtmlAnalysis = new NingBoZhongYiDeathCaseDiscussHtmlAnalysis();
+                Map<String, String> sourceMap = ningBoZhongYiHtmlAnalysis.analysis(content, recTitle, recTypeId);
+                if (MapUtils.isNotEmpty(sourceMap)) {
+                    structureMap = OrdinaryAssistant.mapKeyContrast(sourceMap, keyContrasts);
+                    structureMap.put("记录编号", contentMap.get("recId").toString());
+                    structureMap.put("病历号", contentMap.get("behospitalCode") == null ? null : contentMap.get("behospitalCode").toString());
+                }
+            }
+            if (MapUtils.isNotEmpty(structureMap)) {
+                deathCaseDiscussDoc = ModelDocGenerate.deathCaseDiscussDocGen(structureMap);
+                deathCaseDiscussDoc.setPageData((Map) structureMap);
+            }
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return deathCaseDiscussDoc;
+    }
+
+    private List<String> keyContrasts = Lists.newArrayList(
+            "科室=科别",
+            "病史摘要(经管医师汇报病史)=病史简介",
+            "医生签名时间=记录时间",
+            "讨论主持人=主持人",
+            "参加者=参加人员",
+            "发言记录(包括病史摘要、治疗抢救过程、讨论目的、讨论意见及结论)=讨论内容",
+            "记录者(签名)=记录医生",
+            "主持人小结意见=主持人小结",
+            "讨论意见=讨论内容",
+            "记录者签名=记录医生",
+            "主持人(签名)=主持人签名"
+    );
+
+}

+ 65 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiDeathRecordDocTrans.java

@@ -0,0 +1,65 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.google.common.collect.Lists;
+import com.lantone.qc.pub.model.doc.DeathRecordDoc;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.util.FastJsonUtils;
+import com.lantone.qc.trans.ModelDocTrans;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import com.lantone.qc.trans.comsis.ModelDocGenerate;
+import com.lantone.qc.trans.comsis.OrdinaryAssistant;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiDeathRecordHtmlAnalysis;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiHtmlAnalysis;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections.MapUtils;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description: 死亡记录文档生成
+ * @author: rengb
+ * @time: 2020/3/17 13:23
+ */
+@Slf4j
+public class NingBoZhongYiDeathRecordDocTrans extends ModelDocTrans {
+
+    @Override
+    public DeathRecordDoc extract(MedrecVo medrecVo) {
+        DeathRecordDoc deathRecordDoc = null;
+        try {
+            Map<String, Object> contentMap = ((List<Map>) medrecVo.getContent().get("content")).get(0);
+            String content = contentMap.get("xmlText").toString();
+            Map<String, String> structureMap = null;
+            if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+                structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+            } else {
+                String recTitle = contentMap.get("recTitle").toString();
+                String recTypeId = contentMap.get("recTypeId").toString();
+                NingBoZhongYiHtmlAnalysis ningBoZhongYiHtmlAnalysis = new NingBoZhongYiDeathRecordHtmlAnalysis();
+                Map<String, String> sourceMap = ningBoZhongYiHtmlAnalysis.analysis(content, recTitle, recTypeId);
+                if (MapUtils.isNotEmpty(sourceMap)) {
+                    structureMap = OrdinaryAssistant.mapKeyContrast(sourceMap, keyContrasts);
+                    structureMap.put("记录编号", contentMap.get("recId").toString());
+                    structureMap.put("病历号", contentMap.get("behospitalCode") == null ? null : contentMap.get("behospitalCode").toString());
+                }
+            }
+            if (MapUtils.isNotEmpty(structureMap)) {
+                deathRecordDoc = ModelDocGenerate.deathRecordDocGen(structureMap);
+                deathRecordDoc.setText(CommonAnalysisUtil.html2String(content));
+                deathRecordDoc.setPageData((Map) structureMap);
+            }
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return deathRecordDoc;
+    }
+
+    private List<String> keyContrasts = Lists.newArrayList(
+            "签名时间=记录时间",
+            "科室=科别",
+            "死亡时间=死亡日期",
+            "医生签名=记录医生"
+    );
+
+}

+ 93 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiDifficultCaseDiscussDocTrans.java

@@ -0,0 +1,93 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.google.common.collect.Lists;
+import com.lantone.qc.pub.model.doc.DifficultCaseDiscussDoc;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.util.FastJsonUtils;
+import com.lantone.qc.trans.ModelDocTrans;
+import com.lantone.qc.trans.comsis.ModelDocGenerate;
+import com.lantone.qc.trans.comsis.OrdinaryAssistant;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiDifficultCaseDiscussHtmlAnalysis;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiHtmlAnalysis;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections.MapUtils;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description: 疑难病例讨论记录文档生成
+ * @author: rengb
+ * @time: 2020/3/17 13:23
+ */
+@Slf4j
+public class NingBoZhongYiDifficultCaseDiscussDocTrans extends ModelDocTrans {
+
+    @Override
+    public List<DifficultCaseDiscussDoc> extract(MedrecVo medrecVo) {
+        List<DifficultCaseDiscussDoc> retList = Lists.newArrayList();
+        List<Map<String, Object>> contentMaps = (List) medrecVo.getContent().get("content");
+        contentMaps.forEach(contentMap -> {
+            try {
+                DifficultCaseDiscussDoc difficultCaseDiscussDoc = getDifficultCaseDiscussDoc(contentMap);
+                if (difficultCaseDiscussDoc != null) {
+                    retList.add(difficultCaseDiscussDoc);
+                }
+            } catch (Exception e) {
+                log.error(e.getMessage(), e);
+            }
+        });
+        return retList;
+    }
+
+    private DifficultCaseDiscussDoc getDifficultCaseDiscussDoc(Map<String, Object> contentMap) {
+        String content = contentMap.get("xmlText").toString();
+        Map<String, String> structureMap = null;
+        if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+            structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+        } else {
+            String recTitle = contentMap.get("recTitle").toString();
+            String recTypeId = contentMap.get("recTypeId").toString();
+            NingBoZhongYiHtmlAnalysis ningBoZhongYiHtmlAnalysis = new NingBoZhongYiDifficultCaseDiscussHtmlAnalysis();
+            Map<String, String> sourceMap = ningBoZhongYiHtmlAnalysis.analysis(content, recTitle, recTypeId);
+            /*if (!sourceMap.containsKey("具体讨论意见") && sourceMap.containsKey("参加人员")) {
+                String participant = sourceMap.get("参加人员");
+                if (participant.contains("医师汇报病史")) {
+                    String parCrew = "";
+                    //参加人员
+                    if (participant.indexOf("医师汇报病史") > 2) {
+                        parCrew = participant.substring(0, participant.indexOf("医师汇报病史") - 2);
+                    }
+                    //具体讨论意见
+                    String SpeDiscussion = participant.substring(Math.max(0, participant.indexOf("医师汇报病史") - 2));
+                    sourceMap.put("参加人员", parCrew);
+                    sourceMap.put("具体讨论意见", SpeDiscussion);
+                }
+            }*/
+
+            if (MapUtils.isNotEmpty(sourceMap)) {
+                structureMap = OrdinaryAssistant.mapKeyContrast(sourceMap, keyContrasts);
+                structureMap.put("记录编号", contentMap.get("recId").toString());
+                structureMap.put("病历号", contentMap.get("behospitalCode") == null ? null : contentMap.get("behospitalCode").toString());
+            }
+        }
+        if (MapUtils.isNotEmpty(structureMap)) {
+            DifficultCaseDiscussDoc difficultCaseDiscussDoc = ModelDocGenerate.difficultCaseDiscussDocGen(structureMap);
+            difficultCaseDiscussDoc.setPageData((Map) structureMap);
+            return difficultCaseDiscussDoc;
+        } else {
+            return null;
+        }
+    }
+
+    private List<String> keyContrasts = Lists.newArrayList(
+            "床位=床号",
+            "讨论主持人=主持人姓名及专业技术职务",
+            "参加讨论人=参加人员的姓名及专业技术职务",
+            "病史简要=汇报病史",
+            "病史摘要=汇报病史",
+            "讨论意见=具体讨论意见",
+            "主持人小结=主持人总结"
+    );
+
+}

+ 36 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiDoctorAdviceDocTrans.java

@@ -0,0 +1,36 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.google.common.collect.Lists;
+import com.lantone.qc.pub.model.doc.DoctorAdviceDoc;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.util.FastJsonUtils;
+import com.lantone.qc.trans.ModelDocTrans;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description: 医嘱信息文档生成
+ * @author: rengb
+ * @time: 2020/3/19 19:41
+ */
+public class NingBoZhongYiDoctorAdviceDocTrans extends ModelDocTrans {
+
+    @Override
+    public List<DoctorAdviceDoc> extract(MedrecVo medrecVo) {
+        List<DoctorAdviceDoc> retList = Lists.newArrayList();
+        List<String> contents = (List) medrecVo.getContent().get("content");
+        contents.forEach(content -> {
+            retList.add(getDoctorAdviceDoc((Map) FastJsonUtils.getJsonToMap(content)));
+        });
+        return retList;
+    }
+
+    private DoctorAdviceDoc getDoctorAdviceDoc(Map<String, String> content) {
+        DoctorAdviceDoc doctorAdviceDoc = new DoctorAdviceDoc();
+        doctorAdviceDoc.setStructureMap(content);
+        doctorAdviceDoc.setPageData((Map) content);
+        return doctorAdviceDoc;
+    }
+
+}

+ 72 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiDutyShiftSystemDocTrans.java

@@ -0,0 +1,72 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.google.common.collect.Lists;
+import com.lantone.qc.pub.model.doc.DutyShiftSystemDoc;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.util.FastJsonUtils;
+import com.lantone.qc.trans.ModelDocTrans;
+import com.lantone.qc.trans.comsis.ModelDocGenerate;
+import com.lantone.qc.trans.comsis.OrdinaryAssistant;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiDutyShiftSystemHtmlAnalysis;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiHtmlAnalysis;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections.MapUtils;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description: 值班交接制度文档生成
+ * @author: rengb
+ * @time: 2020/3/17 13:24
+ */
+@Slf4j
+public class NingBoZhongYiDutyShiftSystemDocTrans extends ModelDocTrans {
+
+    @Override
+    public List<DutyShiftSystemDoc> extract(MedrecVo medrecVo) {
+        List<DutyShiftSystemDoc> retList = Lists.newArrayList();
+        List<Map<String, Object>> contentMaps = (List) medrecVo.getContent().get("content");
+        contentMaps.forEach(contentMap -> {
+            try {
+                DutyShiftSystemDoc dutyShiftSystemDoc = getDutyShiftSystemDoc(contentMap);
+                if (dutyShiftSystemDoc != null) {
+                    retList.add(dutyShiftSystemDoc);
+                }
+            } catch (Exception e) {
+                log.error(e.getMessage(), e);
+            }
+        });
+        return retList;
+    }
+
+    private DutyShiftSystemDoc getDutyShiftSystemDoc(Map<String, Object> contentMap) {
+        String content = contentMap.get("xmlText").toString();
+        Map<String, String> structureMap = null;
+        if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+            structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+        } else {
+            String recTitle = contentMap.get("recTitle").toString();
+            String recTypeId = contentMap.get("recTypeId").toString();
+            NingBoZhongYiHtmlAnalysis ningBoZhongYiHtmlAnalysis = new NingBoZhongYiDutyShiftSystemHtmlAnalysis();
+            Map<String, String> sourceMap = ningBoZhongYiHtmlAnalysis.analysis(content, recTitle, recTypeId);
+            if (MapUtils.isNotEmpty(sourceMap)) {
+                structureMap = OrdinaryAssistant.mapKeyContrast(sourceMap, keyContrasts);
+                structureMap.put("记录编号", contentMap.get("recId").toString());
+                structureMap.put("病历号", contentMap.get("behospitalCode") == null ? null : contentMap.get("behospitalCode").toString());
+            }
+        }
+        if (MapUtils.isNotEmpty(structureMap)) {
+            DutyShiftSystemDoc dutyShiftSystemDoc = ModelDocGenerate.dutyShiftSystemDocGen(structureMap);
+            dutyShiftSystemDoc.setPageData((Map) structureMap);
+            return dutyShiftSystemDoc;
+        } else {
+            return null;
+        }
+    }
+
+    private List<String> keyContrasts = Lists.newArrayList(
+
+    );
+
+}

+ 83 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiFirstCourseRecordDocTrans.java

@@ -0,0 +1,83 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.lantone.qc.pub.model.doc.FirstCourseRecordDoc;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.util.FastJsonUtils;
+import com.lantone.qc.pub.util.StringUtil;
+import com.lantone.qc.trans.ModelDocTrans;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import com.lantone.qc.trans.comsis.ModelDocGenerate;
+import com.lantone.qc.trans.comsis.OrdinaryAssistant;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiFirstCourseRecordHtmlAnalysis;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiHtmlAnalysis;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections.MapUtils;
+
+import java.util.List;
+import java.util.Map;
+
+import static com.lantone.qc.trans.comsis.ModelDocGenerate.structureMapJoin;
+
+/**
+ * @Description: 首次病程录文档生成
+ * @author: rengb
+ * @time: 2020/3/17 13:25
+ */
+@Slf4j
+public class NingBoZhongYiFirstCourseRecordDocTrans extends ModelDocTrans {
+
+    @Override
+    public FirstCourseRecordDoc extract(MedrecVo medrecVo) {
+        FirstCourseRecordDoc firstCourseRecordDoc = null;
+        try {
+            Map<String, Object> contentMap = ((List<Map>) medrecVo.getContent().get("content")).get(0);
+            String content = contentMap.get("xmlText").toString();
+            Map<String, String> structureMap = null;
+            if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+                structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+            } else {
+                String recTitle = contentMap.get("recTitle").toString();
+                String recTypeId = contentMap.get("recTypeId").toString();
+                NingBoZhongYiHtmlAnalysis ningBoZhongYiHtmlAnalysis = new NingBoZhongYiFirstCourseRecordHtmlAnalysis();
+                Map<String, String> sourceMap = ningBoZhongYiHtmlAnalysis.analysis(content, recTitle, recTypeId);
+                if (MapUtils.isNotEmpty(sourceMap)) {
+                    sourceMap = removeSerialNumber(sourceMap);
+                    structureMap = OrdinaryAssistant.mapKeyContrast(sourceMap, keyContrasts);
+                    structureMap.put("记录编号", contentMap.get("recId").toString());
+                    structureMap.put("病历号", contentMap.get("behospitalCode") == null ? null : contentMap.get("behospitalCode").toString());
+                    structureMap.put("标题", recTitle);
+                }
+            }
+            if (StringUtil.isNotBlank(structureMap.get("医生签名"))) {
+                structureMap.put("医生签名", structureMap.get("医生签名").replaceAll("医生签名", ""));
+            }
+            if (MapUtils.isNotEmpty(structureMap)) {
+                firstCourseRecordDoc = ModelDocGenerate.firstCourseRecordDocGen(structureMap);
+                firstCourseRecordDoc.setText(CommonAnalysisUtil.html2String(content));
+                firstCourseRecordDoc.setPageData((Map) structureMap);
+                List<String> keys = Lists.newArrayList("需求评估", "预期目标", "诊疗计划", "治疗监测计划");
+                String treatPlanJoin = structureMapJoin(structureMap, keys);
+                firstCourseRecordDoc.getTreatPlanLabel().setAiText(treatPlanJoin);
+            }
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return firstCourseRecordDoc;
+    }
+
+    private Map<String, String> removeSerialNumber(Map<String, String> sourceMap) {
+        Map<String, String> structureMap = Maps.newLinkedHashMap();
+        sourceMap.forEach((key, value) -> structureMap.put(key.replaceAll("[一二三四五六()().123456]", ""), value));
+        return structureMap;
+    }
+
+    private List<String> keyContrasts = Lists.newArrayList(
+            "时间=病历日期",
+            "病历特点=病例特点",
+            "入院查体=查体",
+            "辅助检查=辅检"
+    );
+
+}

+ 54 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiFirstPageRecordDocTrans.java

@@ -0,0 +1,54 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.google.common.collect.Maps;
+import com.lantone.qc.dbanaly.util.ModuleMappingUtil;
+import com.lantone.qc.pub.Content;
+import com.lantone.qc.pub.model.doc.FirstPageRecordDoc;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.util.FastJsonUtils;
+import com.lantone.qc.trans.ModelDocTrans;
+
+import java.util.Map;
+
+/**
+ * @Description: 病案首页文档生成
+ * @author: 胡敬
+ * @time: 2020/3/16 17:47
+ */
+public class NingBoZhongYiFirstPageRecordDocTrans extends ModelDocTrans {
+
+    @Override
+    public FirstPageRecordDoc extract(MedrecVo medrecVo) {
+        Map<String, String> content = (Map) medrecVo.getContent();
+        FirstPageRecordDoc firstPageRecordDoc = new FirstPageRecordDoc();
+        firstPageRecordDoc.setStructureMap(content);
+
+        Map<String, Object> structureExtMap = Maps.newHashMap();
+        structureExtMap.putAll(content);
+        structureExtMap.put(Content.diagnose_cts, FastJsonUtils.getJsonToBean(content.get(Content.diagnose_cts), Object.class));
+        //        structureExtMap.put(Content.outpatientEmergencyDiag, FastJsonUtils.getJsonToBean(content.get(Content.outpatientEmergencyDiag), Object.class));
+        structureExtMap.put(Content.operative_information, FastJsonUtils.getJsonToBean(content.get(Content.operative_information), Object.class));
+        structureExtMap.put(Content.dischargeDiag, FastJsonUtils.getJsonToBean(content.get(Content.dischargeDiag), Object.class));
+        //        structureExtMap.put(Content.pathologyDiagnose, FastJsonUtils.getJsonToBean(content.get(Content.pathologyDiagnose), Object.class));
+        firstPageRecordDoc.setStructureExtMap(structureExtMap);
+        //病案首页出院诊断页面信息只保留主要诊断和其他诊断
+        /*List<Map<String, String>> list = (List<Map<String, String>>) FastJsonUtils.getJsonToBean(content.get(Content.dischargeDiag), Object.class);
+        if (ListUtil.isNotEmpty(list)) {
+            Iterator<Map<String, String>> iterator = list.iterator();
+            Map<String, String> map = new HashMap<>();
+            while (iterator.hasNext()) {
+                map = new HashMap<>();
+                map = iterator.next();
+                if (!((map.get("诊断类别") != null && map.get("诊断类别").equals("主要诊断"))
+                        || (map.get("诊断类别") != null && map.get("诊断类别").equals("其他诊断")))) {
+                    iterator.remove();
+                }
+            }
+            medrecVo.getContent().put("出院诊断", list.toString());
+        }*/
+        medrecVo.getContent().put("mode_id", ModuleMappingUtil.getStandardModuleId("6"));
+        firstPageRecordDoc.setPageData(medrecVo.getContent());
+        return firstPageRecordDoc;
+    }
+
+}

+ 90 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiLeaveHospitalDocTrans.java

@@ -0,0 +1,90 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.google.common.collect.Lists;
+import com.lantone.qc.pub.model.doc.LeaveHospitalDoc;
+import com.lantone.qc.pub.model.label.LeaveHospitalDoctorAdviceLabel;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.util.FastJsonUtils;
+import com.lantone.qc.trans.ModelDocTrans;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import com.lantone.qc.trans.comsis.ModelDocGenerate;
+import com.lantone.qc.trans.comsis.OrdinaryAssistant;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiHtmlAnalysis;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiLeaveHospitalHtmlAnalysis;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections.MapUtils;
+import org.apache.commons.lang3.StringUtils;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description: 出院小结文档生成
+ * @author: rengb
+ * @time: 2020/3/17 13:25
+ */
+@Slf4j
+public class NingBoZhongYiLeaveHospitalDocTrans extends ModelDocTrans {
+
+    @Override
+    public LeaveHospitalDoc extract(MedrecVo medrecVo) {
+        LeaveHospitalDoc leaveHospitalDoc = null;
+        try {
+            Map<String, Object> contentMap = ((List<Map>) medrecVo.getContent().get("content")).get(0);
+            String content = contentMap.get("xmlText").toString();
+            Map<String, String> structureMap = null;
+            if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+                structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+            } else {
+                String recTitle = contentMap.get("recTitle").toString();
+                String recTypeId = contentMap.get("recTypeId").toString();
+                NingBoZhongYiHtmlAnalysis ningBoZhongYiHtmlAnalysis = new NingBoZhongYiLeaveHospitalHtmlAnalysis();
+                Map<String, String> sourceMap = ningBoZhongYiHtmlAnalysis.analysis(content, recTitle, recTypeId);
+                if (MapUtils.isNotEmpty(sourceMap)) {
+                    structureMap = OrdinaryAssistant.mapKeyContrast(sourceMap, keyContrasts);
+                    structureMap.put("记录编号", contentMap.get("recId").toString());
+                    structureMap.put("病历号", contentMap.get("behospitalCode") == null ? null : contentMap.get("behospitalCode").toString());
+                }
+            }
+            if (MapUtils.isNotEmpty(structureMap)) {
+                leaveHospitalDoc = ModelDocGenerate.leaveHospitalDocGen(structureMap);
+                if (StringUtils.isNotEmpty(structureMap.get("出院医嘱"))) {
+                    LeaveHospitalDoctorAdviceLabel leaveHospitalDoctorAdviceLabel = new LeaveHospitalDoctorAdviceLabel();
+                    leaveHospitalDoctorAdviceLabel.setText(structureMap.get("出院医嘱"));
+                    leaveHospitalDoctorAdviceLabel.setAiText(structureMap.get("出院医嘱"));
+                    leaveHospitalDoc.setLeaveHospitalDoctorAdviceLabel(leaveHospitalDoctorAdviceLabel);
+                }
+                leaveHospitalDoc.setText(CommonAnalysisUtil.html2String(content));
+                leaveHospitalDoc.setPageData((Map) structureMap);
+            }
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return leaveHospitalDoc;
+    }
+
+    private List<String> keyContrasts = Lists.newArrayList(
+            "患者姓名=姓名",
+            "性别=",
+            "床号=",
+            "年龄=",
+            "科室=科别",
+            "入院时间=入院日期",
+            "入院诊断=入院诊断",
+            "出院诊断=出院诊断",
+            "实际住院天数=住院天数",
+            "入院情况=病史摘要",
+            "诊疗经过=诊治经过",
+            "住院重要检查化验结果=主要实验室检查及器械检验结果",
+            "出院情况=",
+            "出院医嘱=",
+            "随访计划=",
+            "医生签名=记录医生",
+            "日期=记录时间",
+            "治疗效果=治疗结果",
+            "其它=其他",
+            "出生年月=出生日期",
+            "床位=床号"
+    );
+
+}

+ 36 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiLisDocTrans.java

@@ -0,0 +1,36 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.google.common.collect.Lists;
+import com.lantone.qc.pub.model.doc.LisDoc;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.util.FastJsonUtils;
+import com.lantone.qc.trans.ModelDocTrans;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description: 化验信息文档生成
+ * @author: rengb
+ * @time: 2020/3/19 19:41
+ */
+public class NingBoZhongYiLisDocTrans extends ModelDocTrans {
+
+    @Override
+    public List<LisDoc> extract(MedrecVo medrecVo) {
+        List<LisDoc> retList = Lists.newArrayList();
+        List<String> contents = (List) medrecVo.getContent().get("content");
+        contents.forEach(content -> {
+            retList.add(getDoctorAdviceDoc((Map) FastJsonUtils.getJsonToMap(content)));
+        });
+        return retList;
+    }
+
+    private LisDoc getDoctorAdviceDoc(Map<String, String> content) {
+        LisDoc doctorAdviceDoc = new LisDoc();
+        doctorAdviceDoc.setStructureMap(content);
+        doctorAdviceDoc.setPageData((Map) content);
+        return doctorAdviceDoc;
+    }
+
+}

+ 26 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiMedicalRecordInfoDocTrans.java

@@ -0,0 +1,26 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.lantone.qc.pub.model.doc.MedicalRecordInfoDoc;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.trans.ModelDocTrans;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description: 住院病历信息
+ * @author: 胡敬
+ * @time: 2020/6/3 15:45
+ */
+public class NingBoZhongYiMedicalRecordInfoDocTrans extends ModelDocTrans {
+
+    @Override
+    public MedicalRecordInfoDoc extract(MedrecVo medrecVo) {
+        Map<String, String> content = (Map) ((List) medrecVo.getContent().get("content")).get(0);
+        MedicalRecordInfoDoc medicalRecordInfoDoc = new MedicalRecordInfoDoc();
+        medicalRecordInfoDoc.setStructureMap(content);
+        medicalRecordInfoDoc.setPageData(medrecVo.getContent());
+        return medicalRecordInfoDoc;
+    }
+
+}

+ 460 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiOperationDocTrans.java

@@ -0,0 +1,460 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.google.common.collect.Sets;
+import com.lantone.qc.pub.model.doc.operation.*;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.util.FastJsonUtils;
+import com.lantone.qc.pub.util.ListUtil;
+import com.lantone.qc.pub.util.StringUtil;
+import com.lantone.qc.trans.ModelDocTrans;
+import com.lantone.qc.trans.comsis.ModelDocGenerate;
+import com.lantone.qc.trans.comsis.OrdinaryAssistant;
+import com.lantone.qc.trans.ningbozhongyi.util.*;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections.MapUtils;
+import org.jsoup.Jsoup;
+
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+
+/**
+ * @Description: 手术文档生成
+ * @author: rengb
+ * @time: 2020/3/20 17:11
+ */
+@Slf4j
+public class NingBoZhongYiOperationDocTrans extends ModelDocTrans {
+
+    @Override
+    public List<OperationDoc> extract(MedrecVo medrecVo) {
+        List<OperationDoc> retList = Lists.newArrayList();
+
+        Map<String, List<String>> contentMap = (Map) medrecVo.getContent().get("content");
+        if (contentMap == null) {
+            return retList;
+        }
+
+        Map<String, OperationDiscussionDoc> operationDiscussionDocMap = getOperationDiscussionDocMap((List) contentMap.get("术后首次病程及谈话记录"));
+        Map<String, OperationRecordDoc> operationRecordDocMap = getOperationRecordDocMap((List) contentMap.get("手术记录"));
+        Map<String, PreoperativeDiscussionDoc> preoperativeDiscussionDocMap = getPreoperativeDiscussionDocMap((List) contentMap.get("术前讨论、术前小结"));
+        Map<String, OperationInformedConsentDoc> operationInformedConsentDocMap = getOperationInformedConsentDocMap((List) contentMap.get("手术知情同意书"));
+        Map<String, OperationSafetyChecklistDoc> operationSafetyChecklistDocMap = getOperationSafetyChecklistDocMap((List) contentMap.get("手术安全核查表"));
+
+        Set<String> operationNameSet = Sets.newHashSet();
+        operationNameSet.addAll(operationDiscussionDocMap.keySet());
+        operationNameSet.addAll(operationRecordDocMap.keySet());
+        operationNameSet.addAll(preoperativeDiscussionDocMap.keySet());
+
+        operationNameSet.forEach(operationName -> {
+            OperationDoc operationDoc = new OperationDoc();
+            operationDoc.setOperationName(operationName);
+            operationDoc.setOperationDiscussionDoc(operationDiscussionDocMap.get(operationName));
+            operationDoc.setOperationRecordDoc(operationRecordDocMap.get(operationName));
+            operationDoc.setPreoperativeDiscussionDoc(preoperativeDiscussionDocMap.get(operationName));
+            operationDoc.setOperationInformedConsentDoc(operationInformedConsentDocMap.get(operationName));
+            operationDoc.setOperationSafetyChecklistDoc(operationSafetyChecklistDocMap.get(operationName));
+            retList.add(operationDoc);
+        });
+
+        return retList;
+    }
+
+
+    /*******************************************术后首次病程及谈话记录***************************************************/
+    private Map<String, OperationDiscussionDoc> getOperationDiscussionDocMap(List<Map<String, Object>> contentMaps) {
+        Map<String, OperationDiscussionDoc> retMap = Maps.newHashMap();
+        if (ListUtil.isEmpty(contentMaps)) {
+            return retMap;
+        }
+        int index = 1;
+        String operationName = null;
+        for (Map<String, Object> contentMap : contentMaps) {
+            if (contentMap.get("xmlText") == null || StringUtil.isBlank(contentMap.get("xmlText").toString())) {
+                continue;
+            }
+            try {
+                OperationDiscussionDoc operationDiscussionDoc = getOperationDiscussionDoc(contentMap);
+                if (operationDiscussionDoc != null) {
+                    operationName = index + "";
+                    operationDiscussionDoc.setOperationName(operationName);
+                    retMap.put(operationName, operationDiscussionDoc);
+                    index++;
+                }
+            } catch (Exception e) {
+                log.error(e.getMessage(), e);
+            }
+        }
+        return retMap;
+    }
+
+    private OperationDiscussionDoc getOperationDiscussionDoc(Map<String, Object> contentMap) {
+        String content = contentMap.get("xmlText").toString();
+        Map<String, String> structureMap = null;
+        OperationDiscussionDoc operationDiscussionDoc = new OperationDiscussionDoc();
+        if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+            structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+            if (MapUtils.isNotEmpty(structureMap)) {
+                operationDiscussionDoc = ModelDocGenerate.operationDiscussionDocGen(structureMap);
+                operationDiscussionDoc.setText(content);
+                operationDiscussionDoc.setPageData((Map) structureMap);
+                return operationDiscussionDoc;
+            } else {
+                return null;
+            }
+        } else {
+            String recTitle = contentMap.get("recTitle").toString();
+            String recTypeId = contentMap.get("recTypeId").toString();
+            NingBoZhongYiHtmlAnalysis ningBoZhongYiHtmlAnalysis = new NingBoZhongYiOperationHtmlAnalysis();
+            Map<String, String> sourceMap = ningBoZhongYiHtmlAnalysis.analysis(content, recTitle, recTypeId);
+            if (MapUtils.isNotEmpty(sourceMap)) {
+                structureMap = OrdinaryAssistant.mapKeyContrast(sourceMap, operationDiscussion_keyContrasts);
+                structureMap.put("记录编号", contentMap.get("recId").toString());
+                structureMap.put("病历号", contentMap.get("behospitalCode") == null ? null : contentMap.get("behospitalCode").toString());
+            }
+            if (MapUtils.isNotEmpty(structureMap)) {
+                operationDiscussionDoc = ModelDocGenerate.operationDiscussionDocGen(structureMap);
+                String text = NingBoZhongYiHtmlAnalysisUtil.blockDivToStr(Jsoup.parse(content).selectFirst("body").child(0), true);
+                operationDiscussionDoc.setText(text);
+                operationDiscussionDoc.setPageData((Map) structureMap);
+                return operationDiscussionDoc;
+            } else {
+                return null;
+            }
+        }
+    }
+
+    private List<String> operationDiscussion_keyContrasts = Lists.newArrayList(
+            "病历标题=标题",
+            "手术简要经过(包括手术方式、术中所见、过程是否顺利、有无并发症等)=手术简要经过",
+            "病情记录=手术简要经过",
+            "术后诊断=术中后诊断",
+            "患者手术后情况=患者术后情况",
+            "术后应当特别注意观察的事项:=术后注意事项",
+            "术后治疗计划(包括术后应当特别注意观察的事项)=术后注意事项",
+            "医师签名=医生签名"
+    );
+
+
+    /**********************************************手术记录*************************************************************/
+    private Map<String, OperationRecordDoc> getOperationRecordDocMap(List<Map<String, Object>> contentMaps) {
+        Map<String, OperationRecordDoc> retMap = Maps.newHashMap();
+        if (ListUtil.isEmpty(contentMaps)) {
+            return retMap;
+        }
+        int index = 1;
+        String operationName = null;
+        for (Map<String, Object> contentMap : contentMaps) {
+            if (contentMap.get("xmlText") == null || StringUtil.isBlank(contentMap.get("xmlText").toString())) {
+                continue;
+            }
+            try {
+                OperationRecordDoc operationRecordDoc = getOperationRecordDoc(contentMap);
+                if (operationRecordDoc != null) {
+                    operationName = index + "";
+                    operationRecordDoc.setOperationName(operationName);
+                    retMap.put(operationName, operationRecordDoc);
+                    index++;
+                }
+            } catch (Exception e) {
+                log.error(e.getMessage(), e);
+            }
+        }
+        return retMap;
+    }
+
+    private OperationRecordDoc getOperationRecordDoc(Map<String, Object> contentMap) {
+        String content = contentMap.get("xmlText").toString();
+        Map<String, String> structureMap = null;
+        if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+            structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+        } else {
+            String recTitle = contentMap.get("recTitle").toString();
+            String recTypeId = contentMap.get("recTypeId").toString();
+            NingBoZhongYiHtmlAnalysis ningBoZhongYiHtmlAnalysis = new NingBoZhongYiOperationRecordHtmlAnalysis();
+            Map<String, String> sourceMap = ningBoZhongYiHtmlAnalysis.analysis(content, recTitle, recTypeId);
+            //含有手术情况知情书时间特殊处理
+            /*if (sourceMap.containsKey("时间") && sourceMap.get("时间").contains("宁波市北仑区人民医院")) {
+                sourceMap.put("时间", sourceMap.get("时间").substring(0, sourceMap.get("时间").indexOf("宁波市北仑区人民医院")));
+            }*/
+            if (MapUtils.isNotEmpty(sourceMap)) {
+                structureMap = OrdinaryAssistant.mapKeyContrast(sourceMap, operationRecord_keyContrasts);
+                structureMap.put("记录编号", contentMap.get("recId").toString());
+                structureMap.put("病历号", contentMap.get("behospitalCode") == null ? null : contentMap.get("behospitalCode").toString());
+            }
+            List<String> titles = Lists.newArrayList("手术开始时间", "手术结束时间");
+            for (String title : titles) {
+                eliminateDate(structureMap, title);
+            }
+            if (structureMap.containsKey("麻醉人员")) {
+                structureMap.put("麻醉人员", structureMap.get("麻醉人员").replace("\n", "").replaceAll("麻醉人员签名", ""));
+            }
+            if (structureMap.containsKey("接生者")) {
+                structureMap.put("接生者", structureMap.get("接生者").replace("\n", "").replaceAll("接生者签名", ""));
+            }
+
+        }
+        if (MapUtils.isNotEmpty(structureMap)) {
+            OperationRecordDoc operationRecordDoc = ModelDocGenerate.operationRecordDocGen(structureMap);
+            operationRecordDoc.setPageData((Map) structureMap);
+            return operationRecordDoc;
+        } else {
+            return null;
+        }
+    }
+
+    private List<String> operationRecord_keyContrasts = Lists.newArrayList(
+            "手术经过=手术经过及处理",
+            "手术前诊断=术前诊断",
+            "手术中诊断=术中后诊断",
+            "科室=科别",
+            "主刀=主刀医师",
+            "记录者=记录医生",
+            "患者手术后情况=患者术后情况",
+            "麻醉方法=麻醉方式",
+            "麻醉人员=麻醉医师",
+            "手术经过(包括病人体位,切口处理经过及病理标本肉眼所见)=手术经过及处理"
+    );
+
+
+    /**********************************************术前讨论、术前小结****************************************************/
+    private Map<String, PreoperativeDiscussionDoc> getPreoperativeDiscussionDocMap(List<Map<String, Object>> contentMaps) {
+        Map<String, PreoperativeDiscussionDoc> retMap = Maps.newHashMap();
+        if (ListUtil.isEmpty(contentMaps)) {
+            return retMap;
+        }
+        int index = 1;
+        String operationName = null;
+        for (Map<String, Object> contentMap : contentMaps) {
+            if (contentMap.get("xmlText") == null || StringUtil.isBlank(contentMap.get("xmlText").toString())) {
+                continue;
+            }
+            try {
+                PreoperativeDiscussionDoc preoperativeDiscussionDoc = getPreoperativeDiscussionDoc(contentMap);
+                if (preoperativeDiscussionDoc != null) {
+                    operationName = index + "";
+                    preoperativeDiscussionDoc.setOperationName(operationName);
+                    retMap.put(operationName, preoperativeDiscussionDoc);
+                    index++;
+                }
+            } catch (Exception e) {
+                log.error(e.getMessage(), e);
+            }
+        }
+        return retMap;
+    }
+
+    private PreoperativeDiscussionDoc getPreoperativeDiscussionDoc(Map<String, Object> contentMap) {
+        String content = contentMap.get("xmlText").toString();
+        Map<String, String> structureMap = null;
+        if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+            structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+        } else {
+            String recTitle = contentMap.get("recTitle").toString();
+            String recTypeId = contentMap.get("recTypeId").toString();
+            NingBoZhongYiHtmlAnalysis ningBoZhongYiHtmlAnalysis = new NingBoZhongYiPreoperativeHtmlAnalysis();
+            Map<String, String> sourceMap = ningBoZhongYiHtmlAnalysis.analysis(content, recTitle, recTypeId);
+            if (MapUtils.isNotEmpty(sourceMap)) {
+                structureMap = OrdinaryAssistant.mapKeyContrast(sourceMap, preoperativeDiscussion_keyContrasts);
+                structureMap.put("记录编号", contentMap.get("recId").toString());
+                structureMap.put("病历号", contentMap.get("behospitalCode") == null ? null : contentMap.get("behospitalCode").toString());
+            }
+        }
+        List<String> titles = Lists.newArrayList("讨论时间", "手术指征", "注意事项", "术前诊断", "医生签名", "风险及防范措施", "可替代方案", "术前准备", "参加人员");
+        if (structureMap.containsKey("简要病情")) {
+            String value = structureMap.get("简要病情").replaceAll("医师姓名", "").replaceAll("简要病情描述", "");
+            structureMap.put("简要病情", value);
+        }
+        if (structureMap.containsKey("可替代的方案")) {
+            String value = structureMap.get("可替代的方案").replaceAll("可替代方案", "");
+            structureMap.put("可替代的方案", value);
+        }
+        if (structureMap.containsKey("拟施麻醉方式")) {
+            String value = structureMap.get("拟施麻醉方式").replaceAll("麻醉方式", "");
+            structureMap.put("拟施麻醉方式", value);
+        }
+        if (structureMap.containsKey("其他术前相关情况")) {
+            String value = structureMap.get("其他术前相关情况").replaceAll("术者术前查看患者的相关情况", "");
+            structureMap.put("其他术前相关情况", value);
+        }
+        if (structureMap.containsKey("手术指征与禁忌")) {
+            String value = structureMap.get("手术指征与禁忌").replaceAll("手术指征与禁忌征", "");
+            structureMap.put("手术指征与禁忌", value);
+        }
+        for (String title : titles) {
+            eliminateDate(structureMap, title);
+        }
+        if (MapUtils.isNotEmpty(structureMap)) {
+            PreoperativeDiscussionDoc preoperativeDiscussionDoc = ModelDocGenerate.preoperativeDiscussionDocGen(structureMap);
+            preoperativeDiscussionDoc.setPageData((Map) structureMap);
+            return preoperativeDiscussionDoc;
+        } else {
+            return null;
+        }
+    }
+
+    private void eliminateDate(Map<String, String> structureMap, String text) {
+        if (structureMap.containsKey(text)) {
+            String value = structureMap.get(text).replaceAll(text, "");
+            structureMap.put(text, value);
+        }
+    }
+
+    private List<String> preoperativeDiscussion_keyContrasts = Lists.newArrayList(
+            "1.术前诊断=术前诊断",
+            "2.手术指征与禁忌征=手术指征与禁忌",
+            "3.可替代方案=可替代的方案",
+            "4.拟施手术方式、名称及可能的变更=拟施手术方式名称及可能的变更与禁忌症",
+            "5.计划性多次手术=计划性多次手术",
+            "6.拟施麻醉方式=拟施麻醉方式",
+            "5.拟施麻醉方式=拟施麻醉方式",
+            "5.本次手术是否属于计划性多次手术=计划性多次手术",
+            "6.术前特殊准备=术前准备",
+            "7.术前特殊准备=术前准备",
+            "7.主要术中、术后风险及防范措施=风险及防范措施",
+            "8.主要术中、术后风险及防范措施=风险及防范措施",
+            "9.术中、术后注意事项(含护理事项)=术中术后注意事项",
+            "8.术中、术后注意事项(含护理事项)=术中术后注意事项",
+            //"术中、术后注意事项(含护理事项)=术后注意事项",
+            //"拟施手术方式(名称)及可能的变更方案=拟施手术方式、名称及可能的变更与禁忌症",
+            //"术前特殊准备=术前准备",
+            //"手术指征与禁忌征=手术指征与禁忌",
+            "经治医生签字时间=记录时间"
+    );
+
+    /**********************************************手术知情同意书****************************************************/
+    private Map<String, OperationInformedConsentDoc> getOperationInformedConsentDocMap(List<Map<String, Object>> contentMaps) {
+        Map<String, OperationInformedConsentDoc> retMap = Maps.newHashMap();
+        if (ListUtil.isEmpty(contentMaps)) {
+            return retMap;
+        }
+        int index = 1;
+        String operationName = null;
+        for (Map<String, Object> contentMap : contentMaps) {
+            if (contentMap.get("xmlText") == null || StringUtil.isBlank(contentMap.get("xmlText").toString())) {
+                continue;
+            }
+            operationName = index + "";
+            OperationInformedConsentDoc operationInformedConsentDoc = getOperationInformedConsentDoc(contentMap);
+            operationInformedConsentDoc.setOperationName(operationName);
+            retMap.put(operationName, operationInformedConsentDoc);
+            index++;
+        }
+        return retMap;
+    }
+
+    private OperationInformedConsentDoc getOperationInformedConsentDoc(Map<String, Object> contentMap) {
+        String modeId = "16";
+//        String content = contentMap.get("xmlText").toString();
+//        Map<String, String> xmlNodeValueMap = CxXmlUtil.firstLevelNodeValue(content);
+//        xmlNodeValueMap.put("mode_id=" + contentMap.get("modeId").toString(), "");
+//        xmlNodeValueMap.put("rec_title=" + contentMap.get("recTitle").toString(), "");
+//        Map<String, String> structureMap = OrdinaryAssistant.mapKeyContrast(xmlNodeValueMap, operationInformedConsent_keyContrasts, modeId);
+//
+//        String text = CxXmlUtil.getXmlText(content);
+//        Map<String, String> cutWordMap = Preproc.getCutWordMap(true, operationInformedConsent_sourceTitles, text);
+//        cutWordMap.putAll(structureMap);
+//
+//        OperationInformedConsentDoc operationInformedConsentDoc = ModelDocGenerate.operationInformedConsentDocGen(cutWordMap);
+        OperationInformedConsentDoc operationInformedConsentDoc = new OperationInformedConsentDoc();
+//        operationInformedConsentDoc.setText(text);
+//        operationInformedConsentDoc.setPageData((Map) cutWordMap);
+
+        return operationInformedConsentDoc;
+    }
+
+    private List<String> operationInformedConsent_sourceTitles = Lists.newArrayList(
+            "姓名",
+            "性别",
+            "病区",
+            "床号",
+            "病案号",
+            "手术医生",
+            "目前诊断",
+            "手术名称",
+            "手术指征",
+            "风险及并发症",
+            "保守治疗",
+            "其他手术",
+            "签名",
+            "签名时间"
+    );
+
+    private List<String> operationInformedConsent_keyContrasts = Lists.newArrayList(
+            "姓名++++患者姓名=姓名",
+            "性别=",
+            "病区++++病区名称=病区",
+            "床号=",
+            "病案号++++住院号=病案号",
+            "手术医生=",
+            "目前诊断=",
+            "手术名称=",
+            "手术指征=",
+            "风险及并发症=",
+            "++++保守治疗=保守治疗",
+            "++++其他手术=其他手术",
+            "签名++++=签名",
+            "签名时间=签名时间"
+    );
+
+    /**********************************************手术安全核查表****************************************************/
+    private Map<String, OperationSafetyChecklistDoc> getOperationSafetyChecklistDocMap(List<Map<String, Object>> contentMaps) {
+        Map<String, OperationSafetyChecklistDoc> retMap = Maps.newHashMap();
+        if (ListUtil.isEmpty(contentMaps)) {
+            return retMap;
+        }
+        int index = 1;
+        String operationName = null;
+        for (Map<String, Object> contentMap : contentMaps) {
+            if (contentMap.get("xmlText") == null || StringUtil.isBlank(contentMap.get("xmlText").toString())) {
+                continue;
+            }
+            operationName = index + "";
+            OperationSafetyChecklistDoc operationSafetyChecklistDoc = getOperationSafetyChecklistDoc(contentMap);
+            operationSafetyChecklistDoc.setOperationName(operationName);
+            retMap.put(operationName, operationSafetyChecklistDoc);
+            index++;
+        }
+        return retMap;
+    }
+
+    private OperationSafetyChecklistDoc getOperationSafetyChecklistDoc(Map<String, Object> contentMap) {
+        String modeId = "21";
+//        String content = contentMap.get("xmlText").toString();
+//        Map<String, String> xmlNodeValueMap = CxXmlUtil.firstLevelNodeValue(content);
+//        xmlNodeValueMap.put("mode_id=" + contentMap.get("modeId").toString(), "");
+//        xmlNodeValueMap.put("rec_title=" + contentMap.get("recTitle").toString(), "");
+//        Map<String, String> structureMap = OrdinaryAssistant.mapKeyContrast(xmlNodeValueMap, operationSafetyChecklist_keyContrasts, modeId);
+//
+//        String text = CxXmlUtil.getXmlText(content);
+//        Map<String, String> cutWordMap = Preproc.getCutWordMap(true, operationSafetyChecklist_sourceTitles, text);
+//        cutWordMap.putAll(structureMap);
+
+//        OperationSafetyChecklistDoc operationSafetyChecklistDoc = ModelDocGenerate.operationSafetyChecklistDocGen(cutWordMap);
+        OperationSafetyChecklistDoc operationSafetyChecklistDoc = new OperationSafetyChecklistDoc();
+//        operationSafetyChecklistDoc.setText(text);
+//        operationSafetyChecklistDoc.setPageData((Map) cutWordMap);
+
+        return operationSafetyChecklistDoc;
+    }
+
+    private List<String> operationSafetyChecklist_sourceTitles = Lists.newArrayList(
+            "姓名",
+            "性别",
+            "病区",
+            "床号",
+            "病案号",
+            "签名"
+    );
+
+    private List<String> operationSafetyChecklist_keyContrasts = Lists.newArrayList(
+            "姓名++++患者姓名=姓名",
+            "性别",
+            "病区",
+            "床号",
+            "病案号++++住院号=病案号",
+            "签名++++=签名"
+    );
+}

+ 40 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiOutDepDocTrans.java

@@ -0,0 +1,40 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.lantone.qc.pub.model.doc.BeHospitalizedDoc;
+import com.lantone.qc.pub.model.label.ChiefLabel;
+import com.lantone.qc.pub.model.label.PastLabel;
+import com.lantone.qc.pub.model.label.PresentLabel;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.trans.ModelDocTrans;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description: 门诊入院记录文档生成
+ * @author: rengb
+ * @time: 2020/3/19 19:41
+ */
+public class NingBoZhongYiOutDepDocTrans extends ModelDocTrans {
+
+    @Override
+    public BeHospitalizedDoc extract(MedrecVo medrecVo) {
+        BeHospitalizedDoc beHospitalizedDoc = new BeHospitalizedDoc();
+        Map<String, String> structureMap = ((List<Map>) medrecVo.getContent().get("content")).get(0);
+
+        ChiefLabel chiefLabel = new ChiefLabel();
+        chiefLabel.setText(structureMap.get("主诉"));
+        beHospitalizedDoc.setChiefLabel(chiefLabel);
+
+        PresentLabel presentLabel = new PresentLabel();
+        presentLabel.setText(structureMap.get("现病史"));
+        beHospitalizedDoc.setPresentLabel(presentLabel);
+
+        PastLabel pastLabel = new PastLabel();
+        pastLabel.setText(structureMap.get("既往史"));
+        beHospitalizedDoc.setPastLabel(pastLabel);
+
+        return beHospitalizedDoc;
+    }
+
+}

+ 36 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiPacsDocTrans.java

@@ -0,0 +1,36 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.google.common.collect.Lists;
+import com.lantone.qc.pub.model.doc.PacsDoc;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.util.FastJsonUtils;
+import com.lantone.qc.trans.ModelDocTrans;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description: 辅检信息文档生成
+ * @author: zh
+ * @time: 2021/4/7 15:41
+ */
+public class NingBoZhongYiPacsDocTrans extends ModelDocTrans {
+
+    @Override
+    public List<PacsDoc> extract(MedrecVo medrecVo) {
+        List<PacsDoc> retList = Lists.newArrayList();
+        List<String> contents = (List) medrecVo.getContent().get("content");
+        contents.forEach(content -> {
+            retList.add(getDoctorAdviceDoc((Map) FastJsonUtils.getJsonToMap(content)));
+        });
+        return retList;
+    }
+
+    private PacsDoc getDoctorAdviceDoc(Map<String, String> content) {
+        PacsDoc doctorAdviceDoc = new PacsDoc();
+        doctorAdviceDoc.setStructureMap(content);
+        doctorAdviceDoc.setPageData((Map) content);
+        return doctorAdviceDoc;
+    }
+
+}

+ 73 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiRescueDocTrans.java

@@ -0,0 +1,73 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.google.common.collect.Lists;
+import com.lantone.qc.pub.model.doc.RescueDoc;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.util.FastJsonUtils;
+import com.lantone.qc.trans.ModelDocTrans;
+import com.lantone.qc.trans.comsis.ModelDocGenerate;
+import com.lantone.qc.trans.comsis.OrdinaryAssistant;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiHtmlAnalysis;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiRescueHtmlAnalysis;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections.MapUtils;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description: 抢救记录文档生成
+ * @author: rengb
+ * @time: 2020/3/17 17:34
+ */
+@Slf4j
+public class NingBoZhongYiRescueDocTrans extends ModelDocTrans {
+
+    @Override
+    public List<RescueDoc> extract(MedrecVo medrecVo) {
+        List<RescueDoc> retList = Lists.newArrayList();
+        List<Map<String, Object>> contentMaps = (List) medrecVo.getContent().get("content");
+        contentMaps.forEach(contentMap -> {
+            try {
+                RescueDoc rescueDoc = getRescueDoc(contentMap);
+                if (rescueDoc != null) {
+                    retList.add(rescueDoc);
+                }
+            } catch (Exception e) {
+                log.error(e.getMessage(), e);
+            }
+        });
+        return retList;
+    }
+
+    private RescueDoc getRescueDoc(Map<String, Object> contentMap) {
+        String content = contentMap.get("xmlText").toString();
+        Map<String, String> structureMap = null;
+        if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+            structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+        } else {
+            String recTitle = contentMap.get("recTitle").toString();
+            String recTypeId = contentMap.get("recTypeId").toString();
+            NingBoZhongYiHtmlAnalysis ningBoZhongYiHtmlAnalysis = new NingBoZhongYiRescueHtmlAnalysis();
+            Map<String, String> sourceMap = ningBoZhongYiHtmlAnalysis.analysis(content, recTitle, recTypeId);
+            if (MapUtils.isNotEmpty(sourceMap)) {
+                structureMap = OrdinaryAssistant.mapKeyContrast(sourceMap, keyContrasts);
+                structureMap.put("记录编号", contentMap.get("recId").toString());
+                structureMap.put("病历号", contentMap.get("behospitalCode") == null ? null : contentMap.get("behospitalCode").toString());
+            }
+        }
+        if (MapUtils.isNotEmpty(structureMap)) {
+            RescueDoc rescueDoc = ModelDocGenerate.rescueDocGen(structureMap);
+            rescueDoc.setPageData((Map) structureMap);
+            return rescueDoc;
+        } else {
+            return null;
+        }
+    }
+
+    private List<String> keyContrasts = Lists.newArrayList(
+            "病历标题=标题",
+            "病情记录=抢救内容"
+    );
+
+}

+ 73 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiStagesSummaryDocTrans.java

@@ -0,0 +1,73 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.google.common.collect.Lists;
+import com.lantone.qc.pub.model.doc.StagesSummaryDoc;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.util.FastJsonUtils;
+import com.lantone.qc.trans.ModelDocTrans;
+import com.lantone.qc.trans.comsis.ModelDocGenerate;
+import com.lantone.qc.trans.comsis.OrdinaryAssistant;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiHtmlAnalysis;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiStagesSummaryHtmlAnalysis;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections.MapUtils;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description: 阶段小结文档生成
+ * @author: rengb
+ * @time: 2020/3/19 19:41
+ */
+@Slf4j
+public class NingBoZhongYiStagesSummaryDocTrans extends ModelDocTrans {
+
+    @Override
+    public List<StagesSummaryDoc> extract(MedrecVo medrecVo) {
+        List<StagesSummaryDoc> retList = Lists.newArrayList();
+        List<Map<String, Object>> contentMaps = (List) medrecVo.getContent().get("content");
+        contentMaps.forEach(contentMap -> {
+            try {
+                StagesSummaryDoc stagesSummaryDoc = getStagesSummaryDoc(contentMap);
+                if (stagesSummaryDoc != null) {
+                    retList.add(stagesSummaryDoc);
+                }
+            } catch (Exception e) {
+                log.error(e.getMessage(), e);
+            }
+        });
+        return retList;
+    }
+
+    private StagesSummaryDoc getStagesSummaryDoc(Map<String, Object> contentMap) {
+        String content = contentMap.get("xmlText").toString();
+        Map<String, String> structureMap = null;
+        if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+            structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+        } else {
+            String recTitle = contentMap.get("recTitle").toString();
+            String recTypeId = contentMap.get("recTypeId").toString();
+            NingBoZhongYiHtmlAnalysis ningBoZhongYiHtmlAnalysis = new NingBoZhongYiStagesSummaryHtmlAnalysis();
+            Map<String, String> sourceMap = ningBoZhongYiHtmlAnalysis.analysis(content, recTitle, recTypeId);
+            if (MapUtils.isNotEmpty(sourceMap)) {
+                structureMap = OrdinaryAssistant.mapKeyContrast(sourceMap, keyContrasts);
+                structureMap.put("记录编号", contentMap.get("recId").toString());
+                structureMap.put("病历号", contentMap.get("behospitalCode") == null ? null : contentMap.get("behospitalCode").toString());
+            }
+        }
+        if (MapUtils.isNotEmpty(structureMap)) {
+            StagesSummaryDoc stagesSummaryDoc = ModelDocGenerate.stagesSummaryDocGen(structureMap);
+            stagesSummaryDoc.setPageData((Map) structureMap);
+            return stagesSummaryDoc;
+        } else {
+            return null;
+        }
+    }
+
+    private List<String> keyContrasts = Lists.newArrayList(
+            "病历标题=标题",
+            "病情记录=病历内容"
+    );
+
+}

+ 362 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiThreeLevelWardDocTrans.java

@@ -0,0 +1,362 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.google.common.collect.Lists;
+import com.lantone.qc.dbanaly.util.KernelConstants;
+import com.lantone.qc.dbanaly.util.SpecialStorageUtil;
+import com.lantone.qc.pub.model.doc.ThreeLevelWardDoc;
+import com.lantone.qc.pub.model.doc.operation.OperationDoc;
+import com.lantone.qc.pub.model.doc.operation.OperationRecordDoc;
+import com.lantone.qc.pub.model.doc.ward.AttendingDoctorWardDoc;
+import com.lantone.qc.pub.model.doc.ward.DirectorDoctorWardDoc;
+import com.lantone.qc.pub.model.doc.ward.GeneralDoctorWardDoc;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.util.FastJsonUtils;
+import com.lantone.qc.pub.util.SpringContextUtil;
+import com.lantone.qc.pub.util.StringUtil;
+import com.lantone.qc.trans.ModelDocTrans;
+import com.lantone.qc.trans.comsis.OrdinaryAssistant;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiHtmlAnalysis;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiThreeLevelWardHtmlAnalysis;
+import lombok.Setter;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections.MapUtils;
+import org.apache.commons.lang3.StringUtils;
+
+import java.util.Calendar;
+import java.util.Date;
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description: 查房记录文档生成
+ * @author: rengb
+ * @time: 2020/3/17 13:27
+ */
+@Slf4j
+@Setter
+public class NingBoZhongYiThreeLevelWardDocTrans extends ModelDocTrans {
+
+    private List<OperationDoc> operationDocs;
+
+    @Override
+    public List<ThreeLevelWardDoc> extract(MedrecVo medrecVo) {
+        List<ThreeLevelWardDoc> retList = Lists.newArrayList();
+        ThreeLevelWardDoc threeLevelWardDoc = new ThreeLevelWardDoc();
+        List<Map<String, Object>> contentMaps = (List) medrecVo.getContent().get("content");
+        contentMaps.forEach(contentMap -> {
+            try {
+                classifyThreeLevelWardDoc(threeLevelWardDoc, contentMap);
+            } catch (Exception e) {
+                log.error(e.getMessage(), e);
+            }
+        });
+        retList.add(threeLevelWardDoc);
+        return retList;
+    }
+
+    private void classifyThreeLevelWardDoc(ThreeLevelWardDoc threeLevelWardDoc, Map<String, Object> contentMap) {
+        String content = contentMap.get("xmlText").toString();
+        Map<String, String> structureMap = null;
+        if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+            structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+        } else {
+            String recTitle = contentMap.get("recTitle").toString();
+            String recTypeId = contentMap.get("recTypeId").toString();
+            NingBoZhongYiHtmlAnalysis ningBoZhongYiHtmlAnalysis = new NingBoZhongYiThreeLevelWardHtmlAnalysis();
+            Map<String, String> sourceMap = ningBoZhongYiHtmlAnalysis.analysis(content, recTitle, recTypeId);
+            if (MapUtils.isNotEmpty(sourceMap)) {
+                structureMap = OrdinaryAssistant.mapKeyContrast(sourceMap, keyContrasts);
+                structureMap.put("记录编号", contentMap.get("recId").toString());
+                structureMap.put("病历号", contentMap.get("behospitalCode") == null ? null : contentMap.get("behospitalCode").toString());
+            }
+        }
+        if (MapUtils.isEmpty(structureMap)) {
+            return;
+        }
+
+        if (structureMap.containsKey("病情记录")) {
+            structureMap.put("病情记录", structureMap.get("病情记录").replace(" ", ""));
+        }
+        //structureMap.put("查房日期", structureMap.get("记录时间"));
+        /*Map<String, String> cutWordMap = Maps.newHashMap();
+        String text = CxXmlUtil.getXmlText(content);
+        if (StringUtil.isNotBlank(text)) {
+            if (StringUtil.isBlank(structureMap.get("病情记录"))) {
+                structureMap.put("病情记录", text);
+            }
+            cutWordMap = Preproc.getCutWordMap(true, sourceTitles, text);
+            if (StringUtil.isBlank(structureMap.get("记录医师"))) {
+                Pattern p = Pattern.compile("^[^\\u4e00-\\u9fa5]+$");//分词结果如果不包含中文为日期,则不覆盖
+                if (StringUtil.isNotEmpty(cutWordMap.get("医师签名"))) {
+                    Matcher m = p.matcher(cutWordMap.get("医师签名"));
+                    if (!m.matches()) {
+                        structureMap.put("记录医师", cutWordMap.get("医师签名"));
+                    }
+                }
+                if (StringUtil.isNotEmpty(cutWordMap.get("记录医生"))) {
+                    Matcher m = p.matcher(cutWordMap.get("记录医生"));
+                    if (!m.matches()) {
+                        structureMap.put("记录医师", cutWordMap.get("记录医生"));
+                    }
+                }
+            }
+        }
+         */
+
+        //总的查房记录 汇总
+        ThreeLevelWardDoc allDoctorWradDoc = new ThreeLevelWardDoc();
+        allDoctorWradDoc.setStructureMap(structureMap);
+        allDoctorWradDoc.setPageData((Map) structureMap);
+        threeLevelWardDoc.addAllDoctorWradDoc(allDoctorWradDoc);
+
+        //主任医师查房
+        DirectorDoctorWardDoc directorDoctorWardDoc = findDirectorDoctorWardDoc(structureMap);
+        if (directorDoctorWardDoc != null) {
+            threeLevelWardDoc.addDirectorDoctorWardDoc(findDirectorDoctorWardDoc(structureMap));
+        }
+        //主治医师查房
+        AttendingDoctorWardDoc attendingDoctorWardDoc = findAttendingDoctorWardDoc(structureMap);
+        if (attendingDoctorWardDoc != null) {
+            threeLevelWardDoc.addAttendingDoctorWardDoc(attendingDoctorWardDoc);
+        }
+        //普通医师查房
+        if (directorDoctorWardDoc == null && attendingDoctorWardDoc == null) {
+            GeneralDoctorWardDoc generalDoctorWardDoc = new GeneralDoctorWardDoc();
+            generalDoctorWardDoc.setStructureMap(structureMap);
+            generalDoctorWardDoc.setPageData((Map) structureMap);
+            threeLevelWardDoc.addGeneralDoctorWardDoc(generalDoctorWardDoc);
+        }
+
+    }
+
+    /**
+     * 主任医师查房
+     *
+     * @param structureMap
+     */
+    private DirectorDoctorWardDoc findDirectorDoctorWardDoc(Map<String, String> structureMap) {
+        String title = structureMap.get("查房标题");
+        String content = structureMap.get("病情记录");
+        String writTitle = structureMap.get("文书标题");
+        String recordDateStr = structureMap.get("查房日期");
+        Date recordDate = StringUtil.parseDateTime(recordDateStr);
+        //标题有代字
+        DirectorDoctorWardDoc directorDoctorWardDoc = null;
+        if (StringUtil.isNotBlank(title)) {
+            if (title.contains("主刀") || title.contains("术后第")) {
+                String doctorTitle = getDoctorTitle(operationDocs, recordDate, "主刀医师");
+                title = title.replace("主刀", doctorTitle).replace("术后第", doctorTitle);
+            } else if (title.contains("一助")) {
+                String doctorTitle = getDoctorTitle(operationDocs, recordDate, "一助");
+                title = title.replace("一助", doctorTitle);
+            }
+            if ((StringUtils.isNotEmpty(subTitle(title)) && subTitle(title).contains("主任")) || findDirector(content)
+                    || title.contains("三级") || endocrinologyTitle(title)) {
+                directorDoctorWardDoc = new DirectorDoctorWardDoc();
+                directorDoctorWardDoc.setStructureMap(structureMap);
+                directorDoctorWardDoc.setPageData((Map) structureMap);
+            }
+        }
+
+        if (StringUtil.isNotBlank(writTitle)) {
+            if (writTitle.contains("主刀") || writTitle.contains("术后第")) {
+                String doctorTitle = getDoctorTitle(operationDocs, recordDate, "主刀医师");
+                writTitle = writTitle.replace("主刀", doctorTitle).replace("术后第", doctorTitle);
+            } else if (writTitle.contains("一助")) {
+                String doctorTitle = getDoctorTitle(operationDocs, recordDate, "一助");
+                writTitle = writTitle.replace("一助", doctorTitle);
+            }
+            if ((StringUtils.isNotEmpty(subTitle(writTitle)) && subTitle(writTitle).contains("主任")) || findDirector(content)
+                    || writTitle.contains("三级") || endocrinologyTitle(writTitle)) {
+                directorDoctorWardDoc = new DirectorDoctorWardDoc();
+                directorDoctorWardDoc.setStructureMap(structureMap);
+                directorDoctorWardDoc.setPageData((Map) structureMap);
+            }
+        }
+        return directorDoctorWardDoc;
+    }
+
+    /**
+     * 主治医师查房
+     *
+     * @param structureMap
+     */
+    private AttendingDoctorWardDoc findAttendingDoctorWardDoc(Map<String, String> structureMap) {
+        String title = structureMap.get("查房标题");
+        String writTitle = structureMap.get("文书标题");
+        String content = structureMap.get("病情记录");
+        String recordDateStr = structureMap.get("查房日期");
+        Date recordDate = StringUtil.parseDateTime(recordDateStr);
+        AttendingDoctorWardDoc attendingDoctorWardDoc = null;
+        //标题有代字
+        if (StringUtil.isNotBlank(title)) {
+            if (title.contains("主刀") || title.contains("术后第")) {
+                String doctorTitle = getDoctorTitle(operationDocs, recordDate, "主刀医师");
+                title = title.replace("主刀", doctorTitle).replace("术后第", doctorTitle);
+            } else if (title.contains("一助")) {
+                String doctorTitle = getDoctorTitle(operationDocs, recordDate, "一助");
+                title = title.replace("一助", doctorTitle);
+            }
+            if ((StringUtils.isNotEmpty(subTitle(title)) && subTitle(title).contains("主治"))
+                    || findAttend(content) || title.contains("三级") || endocrinologyTitle(title)) {
+                attendingDoctorWardDoc = new AttendingDoctorWardDoc();
+                attendingDoctorWardDoc.setStructureMap(structureMap);
+                attendingDoctorWardDoc.setPageData((Map) structureMap);
+            }
+        }
+
+        //文书标题和模板标题不一致
+        if (StringUtil.isNotBlank(writTitle)) {
+            if (writTitle.contains("主刀") || writTitle.contains("术后第")) {
+                String doctorTitle = getDoctorTitle(operationDocs, recordDate, "主刀医师");
+                writTitle = writTitle.replace("主刀", doctorTitle).replace("术后第", doctorTitle);
+            } else if (writTitle.contains("一助")) {
+                String doctorTitle = getDoctorTitle(operationDocs, recordDate, "一助");
+                writTitle = writTitle.replace("一助", doctorTitle);
+            }
+            if ((StringUtils.isNotEmpty(subTitle(writTitle)) && subTitle(writTitle).contains("主治"))
+                    || findAttend(content) || writTitle.contains("三级") || endocrinologyTitle(writTitle)) {
+                attendingDoctorWardDoc = new AttendingDoctorWardDoc();
+                attendingDoctorWardDoc.setStructureMap(structureMap);
+                attendingDoctorWardDoc.setPageData((Map) structureMap);
+            }
+        }
+        return attendingDoctorWardDoc;
+    }
+
+    /**
+     * 北仑内分泌科主任主治处理
+     *
+     * @param title
+     * @return
+     */
+    private boolean endocrinologyTitle(String title) {
+        String regex = ".*主任.*主任.*主治.*";
+        return title.matches(regex);
+    }
+
+    /**
+     * 共同照护讨论记录中找主任查房
+     *
+     * @param content
+     * @return
+     */
+    private boolean findDirector(String content) {
+        String director = "";
+        if (content.indexOf(",") != -1) {
+            director = content.substring(0, content.indexOf(","));
+        }
+        return director.contains("主任");
+    }
+
+    /**
+     * 共同照护讨论记录中找主治查房
+     *
+     * @param content
+     * @return
+     */
+    private boolean findAttend(String content) {
+        String director = "";
+        if (content.indexOf(",") != -1) {
+            director = content.substring(0, content.indexOf(","));
+        }
+        return director.contains("主治");
+    }
+
+    private String subTitle(String srcText) {
+        if (StringUtil.isNotBlank(srcText) && srcText.contains("代") && srcText.indexOf("代") != srcText.length() - 1) {
+            srcText = srcText.substring(srcText.lastIndexOf("代") + 1);
+        }
+        return srcText;
+    }
+
+    private List<String> keyContrasts = Lists.newArrayList(
+            "病历日期=查房日期",
+            "病历标题=查房标题",
+            "科主任=三级医师",
+            "记录日期=记录时间"
+    );
+
+    /**
+     * 获取主刀医师/一助职称(取距离查房记录时间最近的一次手术记录)
+     *
+     * @param operationDocs
+     * @return
+     */
+    public static String getDoctorTitle(List<OperationDoc> operationDocs, Date recordDate, String findTitle) {
+        String title = "";
+        SpecialStorageUtil specialStorageUtil = SpringContextUtil.getBean("specialStorageUtil");
+        Map<String, Object> surgeon = specialStorageUtil.getJsonStringValue(KernelConstants.HOSPITAL_DOCTOR_MAP);
+        if (surgeon == null) {
+            return title;
+        }
+        /* 用于存放手术结束时间距离查房时间最近的一次时间差 */
+        long timeDiff = 0L;
+        for (OperationDoc operationDoc : operationDocs) {
+            OperationRecordDoc operationRecordDoc = operationDoc.getOperationRecordDoc();
+            if (operationRecordDoc == null) {
+                continue;
+            }
+            Map<String, String> structureMap = operationRecordDoc.getStructureMap();
+            String chiefSurgeon = structureMap.get(findTitle);
+            String operatorEndDateStr = structureMap.get("手术结束时间");
+            if (StringUtil.isBlank(chiefSurgeon)) {
+                chiefSurgeon = structureMap.get("手术者及助手名称");
+                if (StringUtil.isNotBlank(chiefSurgeon) && chiefSurgeon.contains("、")) {
+                    chiefSurgeon = chiefSurgeon.split("、")[0].replace("主刀:", "");
+                }
+            }
+            if (StringUtil.isBlank(chiefSurgeon) || StringUtil.isBlank(operatorEndDateStr)) {
+                continue;
+            }
+            Map<String, String> doctor = (Map) surgeon.get(chiefSurgeon);
+            if (doctor != null) {
+                String professor = doctor.get("professor");
+                Date operatorEndDate = StringUtil.parseDateTime(operatorEndDateStr);
+                if (operatorEndDate != null) {
+                    long timeDifference = timeDifference(operatorEndDate, recordDate);
+                    if (timeDifference == 0) {
+                        continue;
+                    }
+                    if (timeDiff == 0 || timeDiff > timeDifference) {
+                        /* 取距离此次主刀医师查房最近的一次手术时间 */
+                        timeDiff = timeDifference;
+                        title = professor;
+                    }
+                }
+            }
+        }
+        return title;
+    }
+
+    public static long timeDifference(Date firstDate, Date secondDate) {
+        long timeDifference = 0L;
+        if (firstDate == null || secondDate == null) {
+            return timeDifference;
+        }
+        boolean flag = false;
+        if (firstDate.before(secondDate)) {
+            flag = true;
+        }
+        Calendar calendarS = Calendar.getInstance();
+        Calendar calendarE = Calendar.getInstance();
+        long timeS, timeE;
+        try {
+            calendarS.setTime(firstDate);
+            calendarE.setTime(secondDate);
+
+            timeS = calendarS.getTimeInMillis();
+            timeE = calendarE.getTimeInMillis();
+
+            if (flag) {
+                timeDifference = (timeE - timeS) / (1000 * 60);
+            } else {
+                timeDifference = (timeS - timeE) / (1000 * 60);
+            }
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+        return timeDifference;
+    }
+
+}

+ 305 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiTransferRecordDocTrans.java

@@ -0,0 +1,305 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.lantone.qc.pub.model.doc.transferrecord.TransferIntoDoc;
+import com.lantone.qc.pub.model.doc.transferrecord.TransferOutDoc;
+import com.lantone.qc.pub.model.doc.transferrecord.TransferRecordDoc;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.util.FastJsonUtils;
+import com.lantone.qc.pub.util.ListUtil;
+import com.lantone.qc.pub.util.StringUtil;
+import com.lantone.qc.trans.ModelDocTrans;
+import com.lantone.qc.trans.comsis.OrdinaryAssistant;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiHtmlAnalysis;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiTransferIntoHtmlAnalysis;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiTransferOutHtmlAnalysis;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections.MapUtils;
+
+import java.util.*;
+
+/**
+ * @Description: 转科记录文档生成
+ * @author: rengb
+ * @time: 2020/3/20 16:10
+ */
+@Slf4j
+public class NingBoZhongYiTransferRecordDocTrans extends ModelDocTrans {
+
+    @Override
+    public TransferRecordDoc extract(MedrecVo medrecVo) {
+        TransferRecordDoc transferRecordDoc = new TransferRecordDoc();
+
+        Map<String, List<String>> contentMap = (Map) medrecVo.getContent().get("content");
+        if (contentMap == null) {
+            return transferRecordDoc;
+        }
+        List<Map<String, Object>> into = (List) contentMap.get("转入记录");
+        List<Map<String, Object>> out = (List) contentMap.get("转出记录");
+        List<Map<String, Object>> all = new ArrayList<>();
+
+        Map<String, TransferIntoDoc> transferIntoDocMap = new HashMap<>();
+        Map<String, TransferOutDoc> transferOutDocMap = new HashMap<>();
+        if (into != null) {
+            all.addAll(into);
+            transferIntoDocMap = getTransferIntoDocMap(into);
+        }
+        if (out != null) {
+            all.addAll(out);
+            transferOutDocMap = getTransferOutDocMap(out);
+        }
+        Map<String, TransferRecordDoc> transferAllDocMap = getTransferAllDocMap(all);
+
+        //转入
+        Map<Date, TransferIntoDoc> dateRecordIn = new TreeMap<>(new Comparator<Date>() {
+            @Override
+            public int compare(Date o1, Date o2) {
+                // 升序排列
+                return o1.compareTo(o2);
+            }
+        });
+        for (TransferIntoDoc transferIntoDoc : transferIntoDocMap.values()) {
+            Map<String, String> structureMap = transferIntoDoc.getStructureMap();
+            String inDateStr = structureMap.get("转科日期");
+            if (StringUtil.isBlank(inDateStr)) {
+                inDateStr = structureMap.get("病历日期");
+            }
+            Date inDate = StringUtil.parseDateTime(inDateStr);
+            if (inDate == null) {
+                continue;
+            }
+            dateRecordIn.put(inDate, transferIntoDoc);
+        }
+        transferRecordDoc.setTransferIntoDocs(new ArrayList<>(dateRecordIn.values()));
+        //转出
+        Map<Date, TransferOutDoc> dateRecordOut = new TreeMap<>(new Comparator<Date>() {
+            @Override
+            public int compare(Date o1, Date o2) {
+                // 升序排列
+                return o1.compareTo(o2);
+            }
+        });
+        for (TransferOutDoc transferOutDoc : transferOutDocMap.values()) {
+            Map<String, String> structureMap = transferOutDoc.getStructureMap();
+            String outDateStr = structureMap.get("转科日期");
+            if (StringUtil.isBlank(outDateStr)) {
+                outDateStr = structureMap.get("病历日期");
+            }
+            Date outDate = StringUtil.parseDateTime(outDateStr);
+            if (outDate == null) {
+                continue;
+            }
+            dateRecordOut.put(outDate, transferOutDoc);
+        }
+        transferRecordDoc.setTransferOutDocs(new ArrayList<>(dateRecordOut.values()));
+
+        //全部转科记录
+        Map<Date, TransferRecordDoc> dateRecordAll = new TreeMap<>(new Comparator<Date>() {
+            @Override
+            public int compare(Date o1, Date o2) {
+                // 升序排列
+                return o1.compareTo(o2);
+            }
+        });
+        for (TransferRecordDoc transferRecordAllDoc : transferAllDocMap.values()) {
+            Map<String, String> structureMap = transferRecordAllDoc.getStructureMap();
+            String transferDateStr = structureMap.get("转科日期");
+            if (StringUtil.isBlank(transferDateStr)) {
+                transferDateStr = structureMap.get("病历日期");
+            }
+            Date transferDate = StringUtil.parseDateTime(transferDateStr);
+            if (transferDate == null) {
+                continue;
+            }
+            dateRecordAll.put(transferDate, transferRecordAllDoc);
+        }
+        transferRecordDoc.setAllTransferDocs(new ArrayList<>(dateRecordAll.values()));
+
+        return transferRecordDoc;
+    }
+
+
+    /**************************************************转入*******************************************************/
+    private Map<String, TransferIntoDoc> getTransferIntoDocMap(List<Map<String, Object>> contentMaps) {
+        Map<String, TransferIntoDoc> retMap = Maps.newHashMap();
+        if (ListUtil.isEmpty(contentMaps)) {
+            return retMap;
+        }
+        int index = 1;
+        String transferRecordName = null;
+        for (Map<String, Object> contentMap : contentMaps) {
+            if (contentMap.get("xmlText") == null || StringUtil.isBlank(contentMap.get("xmlText").toString())) {
+                continue;
+            }
+            try {
+                TransferIntoDoc transferIntoDoc = getTransferIntoDoc(contentMap);
+                if (transferIntoDoc != null) {
+                    transferRecordName = index + "";
+                    transferIntoDoc.setTransferRecordName(transferRecordName);
+                    retMap.put(transferRecordName, transferIntoDoc);
+                    index++;
+                }
+            } catch (Exception e) {
+                log.error(e.getMessage(), e);
+            }
+        }
+        return retMap;
+    }
+
+    private TransferIntoDoc getTransferIntoDoc(Map<String, Object> contentMap) {
+        String content = contentMap.get("xmlText").toString();
+        Map<String, String> structureMap = new HashMap<>();
+        if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+            structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+        } else {
+            String recTitle = contentMap.get("recTitle").toString();
+            String recTypeId = contentMap.get("recTypeId").toString();
+            NingBoZhongYiHtmlAnalysis ningBoZhongYiHtmlAnalysis = new NingBoZhongYiTransferIntoHtmlAnalysis();
+            Map<String, String> sourceMap = ningBoZhongYiHtmlAnalysis.analysis(content, recTitle, recTypeId);
+            if (MapUtils.isNotEmpty(sourceMap)) {
+                structureMap = OrdinaryAssistant.mapKeyContrast(sourceMap, keyContrasts);
+                structureMap.put("记录编号", contentMap.get("recId").toString());
+                structureMap.put("病历号", contentMap.get("behospitalCode") == null ? null : contentMap.get("behospitalCode").toString());
+            }
+        }
+        //存入转入时间
+        getTransDate(contentMap.get("transferInDate"), "转入时间", structureMap);
+        if (MapUtils.isNotEmpty(structureMap)) {
+            TransferIntoDoc transferIntoDoc = new TransferIntoDoc();
+            transferIntoDoc.setStructureMap(structureMap);
+            transferIntoDoc.setPageData((Map) structureMap);
+            return transferIntoDoc;
+        } else {
+            return null;
+        }
+    }
+
+    /**************************************************全部*******************************************************/
+    private Map<String, TransferRecordDoc> getTransferAllDocMap(List<Map<String, Object>> contentMaps) {
+        Map<String, TransferRecordDoc> retMap = Maps.newHashMap();
+        if (ListUtil.isEmpty(contentMaps)) {
+            return retMap;
+        }
+        int index = 1;
+        String transferRecordName = null;
+        for (Map<String, Object> contentMap : contentMaps) {
+            if (contentMap.get("xmlText") == null || StringUtil.isBlank(contentMap.get("xmlText").toString())) {
+                continue;
+            }
+            try {
+                TransferRecordDoc transferRecordDoc = getTransferAllDoc(contentMap);
+                if (transferRecordDoc != null) {
+                    transferRecordName = index + "";
+                    transferRecordDoc.setTransferRecordName(transferRecordName);
+                    retMap.put(transferRecordName, transferRecordDoc);
+                    index++;
+                }
+            } catch (Exception e) {
+                log.error(e.getMessage(), e);
+            }
+        }
+        return retMap;
+    }
+
+    private TransferRecordDoc getTransferAllDoc(Map<String, Object> contentMap) {
+        String content = contentMap.get("xmlText").toString();
+        Map<String, String> structureMap = new HashMap<>();
+        if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+            structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+        } else {
+            String recTitle = contentMap.get("recTitle").toString();
+            String recTypeId = contentMap.get("recTypeId").toString();
+            NingBoZhongYiHtmlAnalysis ningBoZhongYiHtmlAnalysis = new NingBoZhongYiTransferOutHtmlAnalysis();
+            Map<String, String> sourceMap = ningBoZhongYiHtmlAnalysis.analysis(content, recTitle, recTypeId);
+            if (MapUtils.isNotEmpty(sourceMap)) {
+                structureMap = OrdinaryAssistant.mapKeyContrast(sourceMap, keyContrasts);
+                structureMap.put("记录编号", contentMap.get("recId").toString());
+                structureMap.put("病历号", contentMap.get("behospitalCode") == null ? null : contentMap.get("behospitalCode").toString());
+            }
+        }
+        //存入转入时间
+        getTransDate(contentMap.get("transferInDate"), "转入时间", structureMap);
+        //存入转出时间
+        getTransDate(contentMap.get("transferOutDate"), "转出时间", structureMap);
+        if (MapUtils.isNotEmpty(structureMap)) {
+            TransferRecordDoc transferAllDoc = new TransferRecordDoc();
+            transferAllDoc.setStructureMap(structureMap);
+            transferAllDoc.setPageData((Map) structureMap);
+            return transferAllDoc;
+        } else {
+            return null;
+        }
+    }
+
+
+    /**************************************************转出*******************************************************/
+    private Map<String, TransferOutDoc> getTransferOutDocMap(List<Map<String, Object>> contentMaps) {
+        Map<String, TransferOutDoc> retMap = Maps.newHashMap();
+        if (ListUtil.isEmpty(contentMaps)) {
+            return retMap;
+        }
+        int index = 1;
+        String transferRecordName = null;
+        for (Map<String, Object> contentMap : contentMaps) {
+            if (contentMap.get("xmlText") == null || StringUtil.isBlank(contentMap.get("xmlText").toString())) {
+                continue;
+            }
+            try {
+                TransferOutDoc transferOutDoc = getTransferOutDoc(contentMap);
+                if (transferOutDoc != null) {
+                    transferRecordName = index + "";
+                    transferOutDoc.setTransferRecordName(transferRecordName);
+                    retMap.put(transferRecordName, transferOutDoc);
+                    index++;
+                }
+            } catch (Exception e) {
+                log.error(e.getMessage(), e);
+            }
+        }
+        return retMap;
+    }
+
+    private TransferOutDoc getTransferOutDoc(Map<String, Object> contentMap) {
+        String content = contentMap.get("xmlText").toString();
+        Map<String, String> structureMap = new HashMap<>();
+        if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+            structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+        } else {
+            String recTitle = contentMap.get("recTitle").toString();
+            String recTypeId = contentMap.get("recTypeId").toString();
+            NingBoZhongYiHtmlAnalysis ningBoZhongYiHtmlAnalysis = new NingBoZhongYiTransferOutHtmlAnalysis();
+            Map<String, String> sourceMap = ningBoZhongYiHtmlAnalysis.analysis(content, recTitle, recTypeId);
+            if (MapUtils.isNotEmpty(sourceMap)) {
+                structureMap = OrdinaryAssistant.mapKeyContrast(sourceMap, keyContrasts);
+                structureMap.put("记录编号", contentMap.get("recId").toString());
+                structureMap.put("病历号", contentMap.get("behospitalCode") == null ? null : contentMap.get("behospitalCode").toString());
+            }
+        }
+        //存入转出时间
+        getTransDate(contentMap.get("transferOutDate"), "转出时间", structureMap);
+        if (MapUtils.isNotEmpty(structureMap)) {
+            TransferOutDoc transferOutDoc = new TransferOutDoc();
+            transferOutDoc.setStructureMap(structureMap);
+            transferOutDoc.setPageData((Map) structureMap);
+            return transferOutDoc;
+        } else {
+            return null;
+        }
+    }
+
+    //存入转入转出时间
+    private void getTransDate(Object transferDates, String dateStr, Map<String, String> structureMap) {
+        if (transferDates != null) {
+            structureMap.put(dateStr, transferDates.toString());
+        }
+    }
+
+    private List<String> keyContrasts = Lists.newArrayList(
+            "医师签名=记录医生",
+            "病历标题=标题",
+            "病情记录=病历内容",
+            "签名时间=记录时间"
+    );
+
+}

+ 52 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingBoZhongYiVTEGradeDocTrans.java

@@ -0,0 +1,52 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.lantone.qc.pub.model.doc.VTEGradeDoc;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.util.FastJsonUtils;
+import com.lantone.qc.trans.ModelDocTrans;
+import com.lantone.qc.trans.comsis.ModelDocGenerate;
+import com.lantone.qc.trans.ningbozhongyi.util.NingBoZhongYiVTEGradeHtmlAnalysis;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections.MapUtils;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @ClassName: NingBoZhongYiVTEGradeDocTrans
+ * @Description: VTE评分
+ * @Author songxl
+ * @Date 2021/3/9
+ * @Version 1.0
+ */
+@Slf4j
+public class NingBoZhongYiVTEGradeDocTrans extends ModelDocTrans {
+    @Override
+    public VTEGradeDoc extract(MedrecVo medrecVo) {
+        VTEGradeDoc vteGradeDoc = null;
+        try {
+            Map<String, Object> contentMap = ((List<Map>) medrecVo.getContent().get("content")).get(0);
+            String content = contentMap.get("xmlText").toString();
+            Map<String, String> structureMap = null;
+            if (contentMap.get("isParsed") != null && "1".equals(contentMap.get("isParsed").toString())) {
+                structureMap = (Map) FastJsonUtils.getJsonToMap(content);
+            } else {
+                String recTitle = contentMap.get("recTitle").toString();
+                String recTypeId = contentMap.get("recTypeId").toString();
+                NingBoZhongYiVTEGradeHtmlAnalysis vteGradeHtmlAnalysis = new NingBoZhongYiVTEGradeHtmlAnalysis();
+                Map<String, String> sourceMap = vteGradeHtmlAnalysis.analysis(content, recTitle, recTypeId);
+                if (MapUtils.isNotEmpty(sourceMap)) {
+                    structureMap.putAll(sourceMap);
+                }
+            }
+            if (MapUtils.isNotEmpty(structureMap)) {
+                              ModelDocGenerate.beHospitalizedDocGen(structureMap);
+                vteGradeDoc = ModelDocGenerate.vteGradeDocGen(structureMap);
+                vteGradeDoc.setPageData((Map) structureMap);
+            }
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return vteGradeDoc;
+    }
+}

+ 282 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/NingbozhongyiDocTrans.java

@@ -0,0 +1,282 @@
+package com.lantone.qc.trans.ningbozhongyi;
+
+import com.google.common.collect.Lists;
+import com.lantone.qc.pub.model.InputInfo;
+import com.lantone.qc.pub.model.vo.MedrecVo;
+import com.lantone.qc.pub.model.vo.QueryVo;
+import com.lantone.qc.pub.util.ListUtil;
+import com.lantone.qc.trans.DocTrans;
+import com.lantone.qc.trans.comsis.OrdinaryAssistant;
+import lombok.extern.slf4j.Slf4j;
+
+import java.util.List;
+import java.util.Map;
+import java.util.stream.Collectors;
+
+/**
+ * @ClassName : BeiLunDocTrans
+ * @Description :
+ * @Author : 楼辉荣
+ * @Date: 2020-03-03 19:47
+ */
+@Slf4j
+public class NingbozhongyiDocTrans extends DocTrans {
+
+    @Override
+    protected InputInfo extract(QueryVo queryVo) {
+        InputInfo inputInfo = new InputInfo();
+        for (MedrecVo i : queryVo.getMedrec()) {
+            if (i.getTitle() != null) {
+                if (i.getTitle().equals("会诊")) {
+                    NingBoZhongYiConsultationDocTrans consultationDocTrans = new NingBoZhongYiConsultationDocTrans();
+                    inputInfo.setConsultationDocs(consultationDocTrans.extract(i));
+                }
+                if (i.getTitle().equals("手术")) {
+                    NingBoZhongYiOperationDocTrans operationDocTrans = new NingBoZhongYiOperationDocTrans();
+                    inputInfo.setOperationDocs(operationDocTrans.extract(i));
+                }
+                if (i.getTitle().equals("转科")) {
+                    NingBoZhongYiTransferRecordDocTrans transferRecordDocTrans = new NingBoZhongYiTransferRecordDocTrans();
+                    inputInfo.setTransferRecordDocs(transferRecordDocTrans.extract(i));
+                }
+                if (i.getTitle().equals("入院记录")) {
+                    NingBoZhongYiBeHospitalizedDocTrans beHospitalizedDocTrans = new NingBoZhongYiBeHospitalizedDocTrans();
+                    inputInfo.setBeHospitalizedDoc(beHospitalizedDocTrans.extract(i));
+                }
+                if (i.getTitle().equals("输血/血制品病程记录")) {
+                    NingBoZhongYiClinicalBloodDocTrans clinicalBloodDocTrans = new NingBoZhongYiClinicalBloodDocTrans();
+                    inputInfo.setClinicalBloodDocs(clinicalBloodDocTrans.extract(i));
+                }
+                if (i.getTitle().equals("输血后效果评价")) {
+                    NingBoZhongYiClinicBloodEffectDocTrans clinicBloodEffectDocTrans = new NingBoZhongYiClinicBloodEffectDocTrans();
+                    inputInfo.setClinicBloodEffectDocs(clinicBloodEffectDocTrans.extract(i));
+                }
+                if (i.getTitle().equals("危急值记录")) {
+                    NingBoZhongYiCrisisValueReportDocTrans crisisValueReportDocTrans = new NingBoZhongYiCrisisValueReportDocTrans();
+                    inputInfo.setCrisisValueReportDocs(crisisValueReportDocTrans.extract(i));
+                }
+                if (i.getTitle().equals("危急值")) {
+                    NingBoZhongYiCrisisInfoDocTrans crisisInfoDocTrans = new NingBoZhongYiCrisisInfoDocTrans();
+                    inputInfo.setCrisisInfoDocs(crisisInfoDocTrans.extract(i));
+                }
+                if (i.getTitle().equals("病危通知书")) {
+                    NingBoZhongYiCriticallyIllNoticeDocTrans criticallyIllNoticeDocTrans = new NingBoZhongYiCriticallyIllNoticeDocTrans();
+                    inputInfo.setCriticallyIllNoticeDocs(criticallyIllNoticeDocTrans.extract(i));
+                }
+                if (i.getTitle().equals("死亡病例讨论记录")) {
+                    NingBoZhongYiDeathCaseDiscussDocTrans deathCaseDiscussDocTrans = new NingBoZhongYiDeathCaseDiscussDocTrans();
+                    inputInfo.setDeathCaseDiscussDoc(deathCaseDiscussDocTrans.extract(i));
+                }
+                if (i.getTitle().equals("死亡记录")) {
+                    NingBoZhongYiDeathRecordDocTrans deathRecordDocTrans = new NingBoZhongYiDeathRecordDocTrans();
+                    inputInfo.setDeathRecordDoc(deathRecordDocTrans.extract(i));
+                }
+                if (i.getTitle().equals("疑难病例讨论记录")) {
+                    NingBoZhongYiDifficultCaseDiscussDocTrans difficultCaseDiscussDocTrans = new NingBoZhongYiDifficultCaseDiscussDocTrans();
+                    inputInfo.setDifficultCaseDiscussDocs(difficultCaseDiscussDocTrans.extract(i));
+                }
+                if (i.getTitle().equals("医嘱信息")) {
+                    NingBoZhongYiDoctorAdviceDocTrans doctorAdviceDocTrans = new NingBoZhongYiDoctorAdviceDocTrans();
+                    inputInfo.setDoctorAdviceDocs(doctorAdviceDocTrans.extract(i));
+                }
+                if (i.getTitle().equals("值班交接制度")) {
+                    NingBoZhongYiDutyShiftSystemDocTrans dutyShiftSystemDocTrans = new NingBoZhongYiDutyShiftSystemDocTrans();
+                    inputInfo.setDutyShiftSystemDocs(dutyShiftSystemDocTrans.extract(i));
+                }
+                if (i.getTitle().equals("首次病程录")) {
+                    NingBoZhongYiFirstCourseRecordDocTrans firstCourseRecordDocTrans = new NingBoZhongYiFirstCourseRecordDocTrans();
+                    inputInfo.setFirstCourseRecordDoc(firstCourseRecordDocTrans.extract(i));
+                }
+                if (i.getTitle().equals("病案首页")) {
+                    NingBoZhongYiFirstPageRecordDocTrans firstPageRecordDocTrans = new NingBoZhongYiFirstPageRecordDocTrans();
+                    inputInfo.setFirstPageRecordDoc(firstPageRecordDocTrans.extract(i));
+                }
+                if (i.getTitle().equals("出院小结")) {
+                    NingBoZhongYiLeaveHospitalDocTrans leaveHospitalDocTrans = new NingBoZhongYiLeaveHospitalDocTrans();
+                    inputInfo.setLeaveHospitalDoc(leaveHospitalDocTrans.extract(i));
+                }
+                if (i.getTitle().equals("抢救记录")) {
+                    NingBoZhongYiRescueDocTrans rescueDocTrans = new NingBoZhongYiRescueDocTrans();
+                    inputInfo.setRescueDocs(rescueDocTrans.extract(i));
+                }
+                if (i.getTitle().equals("阶段小结")) {
+                    NingBoZhongYiStagesSummaryDocTrans stagesSummaryDocTrans = new NingBoZhongYiStagesSummaryDocTrans();
+                    inputInfo.setStagesSummaryDocs(stagesSummaryDocTrans.extract(i));
+                }
+                if (i.getTitle().equals("查房记录")) {
+                    NingBoZhongYiThreeLevelWardDocTrans threeLevelWardDocTrans = new NingBoZhongYiThreeLevelWardDocTrans();
+                    threeLevelWardDocTrans.setOperationDocs(inputInfo.getOperationDocs());
+                    inputInfo.setThreeLevelWardDocs(threeLevelWardDocTrans.extract(i));
+                }
+                if (i.getTitle().equals("住院病历信息")) {
+                    NingBoZhongYiMedicalRecordInfoDocTrans medicalRecordInfoDocTrans = new NingBoZhongYiMedicalRecordInfoDocTrans();
+                    inputInfo.setMedicalRecordInfoDoc(medicalRecordInfoDocTrans.extract(i));
+                }
+                if (i.getTitle().equals("化验")) {
+                    NingBoZhongYiLisDocTrans lisDocTrans = new NingBoZhongYiLisDocTrans();
+                    inputInfo.setLisDocs(lisDocTrans.extract(i));
+                }
+                if (i.getTitle().equals("辅检")) {
+                    NingBoZhongYiPacsDocTrans pacsDocTrans = new NingBoZhongYiPacsDocTrans();
+                    inputInfo.setPacsDocs(pacsDocTrans.extract(i));
+                }
+                if (i.getTitle().equals("门诊")) {
+                    NingBoZhongYiOutDepDocTrans outDepDocTrans = new NingBoZhongYiOutDepDocTrans();
+                    inputInfo.setBeHospitalizedDoc(outDepDocTrans.extract(i));
+                }
+                /*******************************VTE评分 trans解析*****************************************/
+                if (i.getTitle().equals("VTE评分")) {
+                    NingBoZhongYiVTEGradeDocTrans vteGradeDocTrans = new NingBoZhongYiVTEGradeDocTrans();
+                    inputInfo.setVteGradeDoc(vteGradeDocTrans.extract(i));
+                }
+                /*******************************ADL评分 trans解析*****************************************/
+                if (i.getTitle().equals("ADL评分")) {
+                    NingBoZhongYiADLGradeDocTrans adlGradeDocTrans = new NingBoZhongYiADLGradeDocTrans();
+                    inputInfo.setAdlGradeDoc(adlGradeDocTrans.extract(i));
+                }
+                /*******************************手麻记录 trans解析*****************************************/
+                if (i.getTitle().equals("手麻记录")) {
+                    AnesthesiaRecordDocTrans anesthesiaRecordDocTrans= new AnesthesiaRecordDocTrans();
+                    inputInfo.setAnesthesiaRecordDocs(anesthesiaRecordDocTrans.extract(i));
+                }
+            }
+        }
+        pageDataHandle(inputInfo);
+        return inputInfo;
+    }
+
+    private void pageDataHandle(InputInfo inputInfo) {
+        if (inputInfo.getBeHospitalizedDoc() != null) {
+            inputInfo.getPageData().put("入院记录", Lists.newArrayList(inputInfo.getBeHospitalizedDoc().getPageData()));
+        }
+        if (inputInfo.getDeathCaseDiscussDoc() != null) {
+            inputInfo.getPageData().put("死亡病例讨论记录", Lists.newArrayList(inputInfo.getDeathCaseDiscussDoc().getPageData()));
+        }
+        if (inputInfo.getDeathRecordDoc() != null) {
+            inputInfo.getPageData().put("死亡记录", Lists.newArrayList(inputInfo.getDeathRecordDoc().getPageData()));
+        }
+        if (inputInfo.getFirstCourseRecordDoc() != null) {
+            inputInfo.getPageData().put("首次病程录", Lists.newArrayList(inputInfo.getFirstCourseRecordDoc().getPageData()));
+        }
+        if (inputInfo.getLeaveHospitalDoc() != null) {
+            inputInfo.getPageData().put("出院小结", Lists.newArrayList(inputInfo.getLeaveHospitalDoc().getPageData()));
+        }
+        if (inputInfo.getFirstPageRecordDoc() != null) {
+            inputInfo.getPageData().put("病案首页", Lists.newArrayList(inputInfo.getFirstPageRecordDoc().getPageData()));
+        }
+
+        if (ListUtil.isNotEmpty(inputInfo.getClinicalBloodDocs())) {
+            inputInfo.getPageData().put("输血/血制品病程记录", inputInfo.getClinicalBloodDocs().stream().map(i -> i.getPageData()).collect(Collectors.toList()));
+//            inputInfo.setClinicalBloodDocs(inputInfo.getClinicalBloodDocs().stream().filter(i -> StringUtil.isNotBlank(i.getText()) && !i.getText().contains("输白蛋白")).collect(Collectors.toList()));
+        }
+        if (ListUtil.isNotEmpty(inputInfo.getClinicBloodEffectDocs())) {
+            inputInfo.getPageData().put(
+                    "输血后效果评价",
+                    inputInfo.getClinicBloodEffectDocs()
+                            .stream()
+                            .map(i -> i.getPageData())
+                            .sorted((map1, map2) -> OrdinaryAssistant.pageDataTimeSort(map1, map2, "记录时间", "yyyy-MM-dd HH:mm"))
+                            .collect(Collectors.toList()));
+        }
+        if (ListUtil.isNotEmpty(inputInfo.getCrisisValueReportDocs())) {
+            inputInfo.getPageData().put("危急值记录", inputInfo.getCrisisValueReportDocs().stream().map(i -> i.getPageData()).collect(Collectors.toList()));
+        }
+        if (ListUtil.isNotEmpty(inputInfo.getCriticallyIllNoticeDocs())) {
+            inputInfo.getPageData().put("病危通知书", inputInfo.getCriticallyIllNoticeDocs().stream().map(i -> i.getPageData()).collect(Collectors.toList()));
+        }
+        if (ListUtil.isNotEmpty(inputInfo.getDifficultCaseDiscussDocs())) {
+            inputInfo.getPageData().put("疑难病例讨论记录", inputInfo.getDifficultCaseDiscussDocs().stream().map(i -> i.getPageData()).collect(Collectors.toList()));
+        }
+        if (ListUtil.isNotEmpty(inputInfo.getDutyShiftSystemDocs())) {
+            inputInfo.getPageData().put("值班交接制度", inputInfo.getDutyShiftSystemDocs().stream().map(i -> i.getPageData()).collect(Collectors.toList()));
+        }
+        if (ListUtil.isNotEmpty(inputInfo.getRescueDocs())) {
+            inputInfo.getPageData().put("抢救记录", inputInfo.getRescueDocs().stream().map(i -> i.getPageData()).collect(Collectors.toList()));
+        }
+        if (ListUtil.isNotEmpty(inputInfo.getStagesSummaryDocs())) {
+            inputInfo.getPageData().put("阶段小结", inputInfo.getStagesSummaryDocs().stream().map(i -> i.getPageData()).collect(Collectors.toList()));
+        }
+        if (ListUtil.isNotEmpty(inputInfo.getThreeLevelWardDocs())) {
+            inputInfo.getPageData().put("查房记录", inputInfo.getThreeLevelWardDocs().get(0).getAllDoctorWradDocs().stream().map(i -> i.getPageData()).collect(Collectors.toList()));
+        }
+        if (ListUtil.isNotEmpty(inputInfo.getConsultationDocs())) {
+            List<Map<String, Object>> crPd = inputInfo.getConsultationDocs()
+                    .stream()
+                    .filter(consultationDoc -> consultationDoc != null && consultationDoc.getConsultationRecordDoc() != null)
+                    .map(consultationDoc -> consultationDoc.getConsultationRecordDoc().getPageData())
+                    .collect(Collectors.toList());
+            if (ListUtil.isNotEmpty(crPd)) {
+                inputInfo.getPageData().put("会诊记录", crPd);
+            }
+
+            List<Map<String, Object>> caPd = inputInfo.getConsultationDocs()
+                    .stream()
+                    .filter(consultationDoc -> consultationDoc != null && consultationDoc.getConsultationApplicationDoc() != null)
+                    .map(consultationDoc -> consultationDoc.getConsultationApplicationDoc().getPageData())
+                    .collect(Collectors.toList());
+            if (ListUtil.isNotEmpty(caPd)) {
+                inputInfo.getPageData().put("会诊申请单", caPd);
+            }
+
+            List<Map<String, Object>> ctPd = inputInfo.getConsultationDocs()
+                    .stream()
+                    .filter(consultationDoc -> consultationDoc != null && consultationDoc.getConsultationResultsDoc() != null)
+                    .map(consultationDoc -> consultationDoc.getConsultationResultsDoc().getPageData())
+                    .collect(Collectors.toList());
+            if (ListUtil.isNotEmpty(ctPd)) {
+                inputInfo.getPageData().put("会诊结果单", ctPd);
+            }
+        }
+        if (ListUtil.isNotEmpty(inputInfo.getOperationDocs())) {
+            List<Map<String, Object>> odPageDataList = inputInfo.getOperationDocs()
+                    .stream()
+                    .filter(operationDoc -> operationDoc != null && operationDoc.getOperationDiscussionDoc() != null)
+                    .map(operationDoc -> operationDoc.getOperationDiscussionDoc().getPageData())
+                    .collect(Collectors.toList());
+            if (ListUtil.isNotEmpty(odPageDataList)) {
+                inputInfo.getPageData().put("术后首次病程及谈话记录", odPageDataList);
+            }
+
+            List<Map<String, Object>> orPageDataList = inputInfo.getOperationDocs()
+                    .stream()
+                    .filter(operationDoc -> operationDoc != null && operationDoc.getOperationRecordDoc() != null)
+                    .map(operationDoc -> operationDoc.getOperationRecordDoc().getPageData())
+                    .collect(Collectors.toList());
+            if (ListUtil.isNotEmpty(orPageDataList)) {
+                inputInfo.getPageData().put("手术记录", orPageDataList);
+            }
+
+            List<Map<String, Object>> pdPageDataList = inputInfo.getOperationDocs()
+                    .stream()
+                    .filter(operationDoc -> operationDoc != null && operationDoc.getPreoperativeDiscussionDoc() != null)
+                    .map(operationDoc -> operationDoc.getPreoperativeDiscussionDoc().getPageData())
+                    .collect(Collectors.toList());
+            if (ListUtil.isNotEmpty(pdPageDataList)) {
+                inputInfo.getPageData().put("术前讨论、术前小结", pdPageDataList);
+            }
+        }
+        if (inputInfo.getTransferRecordDocs() != null) {
+            if (ListUtil.isNotEmpty(inputInfo.getTransferRecordDocs().getTransferIntoDocs())) {
+                inputInfo.getPageData().put(
+                        "转入记录",
+                        inputInfo.getTransferRecordDocs().getTransferIntoDocs()
+                                .stream()
+                                .filter(i -> i != null)
+                                .map(i -> i.getPageData())
+                                .collect(Collectors.toList())
+                );
+            }
+
+            if (ListUtil.isNotEmpty(inputInfo.getTransferRecordDocs().getTransferOutDocs())) {
+                inputInfo.getPageData().put(
+                        "转出记录",
+                        inputInfo.getTransferRecordDocs().getTransferOutDocs()
+                                .stream()
+                                .filter(i -> i != null)
+                                .map(i -> i.getPageData())
+                                .collect(Collectors.toList())
+                );
+            }
+        }
+    }
+}

+ 41 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiADLGradeHtmlAnalysis.java

@@ -0,0 +1,41 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import com.google.common.collect.Maps;
+import com.lantone.qc.pub.Content;
+import lombok.extern.slf4j.Slf4j;
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Document;
+import org.jsoup.select.Elements;
+
+import java.util.Map;
+
+/**
+ * @ClassName:
+ * @Description: ADL评分HTML解析
+ * @Author songxl
+ * @Date 2021/3/9
+ * @Version 1.0
+ */
+@Slf4j
+public class NingBoZhongYiADLGradeHtmlAnalysis implements NingBoZhongYiHtmlAnalysis {
+    private String modeId = "0";//模块id待定
+    @Override
+    public Map<String, String> analysis(String... args) {
+        Map<String, String> map = Maps.newLinkedHashMap();
+        try {
+            String html = args[0];
+            String recTitle = args[1];
+            String recTypeId = args[2];
+
+            Document doc = Jsoup.parse(html);
+            //评估日期
+            Elements spanES = doc.getElementById("table2").nextElementSiblings().get(1).getElementsByTag("span");
+            String time = spanES.text().split(Content.adl_grade_time)[1]
+                    .replaceAll(":","").trim();
+            map.put(Content.adl_grade_time,time);
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return map;
+    }
+}

+ 183 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiBeHospitalizedHtmlAnalysis.java

@@ -0,0 +1,183 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.lantone.qc.pub.util.StringUtil;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Document;
+import org.jsoup.nodes.Element;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description:
+ * @author: rengb
+ * @time: 2020/9/15 16:28
+ */
+@Slf4j
+public class NingBoZhongYiBeHospitalizedHtmlAnalysis implements NingBoZhongYiHtmlAnalysis {
+
+    private String modeId = "1";
+
+    @Override
+    public Map<String, String> analysis(String... args) {
+        Map<String, String> map = Maps.newLinkedHashMap();
+        try {
+            String html = args[0];
+            String recTitle = args[1];
+            String recTypeId = args[2];
+            Document doc = Jsoup.parse(html);
+
+            if (recTitle.contains("24")) {
+                analysis24h(doc, map);
+            } else if (recTitle.contains("日间病历")) {
+                analysisDay(doc, map);
+            } else {
+                analysisGeneral(doc, recTitle, map);
+            }
+            NingBoZhongYiHtmlAnalysisUtil.insertModuleId(modeId, recTypeId, map);
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return map;
+    }
+
+    //一般模板
+    private void analysisGeneral(Document doc, String recTitle, Map<String, String> map) {
+        //个人基础信息table解析
+        String[] patInfoTableElementIds = {"table2", "table2_0"};
+        for (String table : patInfoTableElementIds) {
+            NingBoZhongYiHtmlAnalysisUtil.tableStyle1InsertMap(doc.getElementById(table), map);
+        }
+        map.put("记录时间", map.get("记录日期"));
+        //主诉、现病史等table解析
+        NingBoZhongYiHtmlAnalysisUtil.tableStyle2InsertMap(doc.getElementById("table3"), map);
+        if (StringUtil.isNotBlank(map.get("婚育史月经史")) && map.get("婚育史月经史").contains("经期")) {
+            map.put("婚育史", map.get("婚育史月经史").substring(0, map.get("婚育史月经史").indexOf("经期")));
+        }
+        //体 格 检 查 表(一) table解析
+        Element tgjcTableElement = doc.getElementById("table4");
+        NingBoZhongYiHtmlAnalysisUtil.tableStyle2InsertMap(tgjcTableElement, map);
+
+        //诊断 table解析
+        String disTableElementId = null;
+        Element disTableElement = null;
+        String[] disTableElementIds = {"table5", "table5_2"};
+        for (String eid : disTableElementIds) {
+            disTableElement = doc.getElementById(eid);
+            if (disTableElement != null) {
+                disTableElementId = eid;
+                break;
+            }
+        }
+
+        if (StringUtil.isNotBlank(map.get("补充诊断"))) {
+            map.put("补充诊断", map.get("补充诊断").replace("\n", " "));
+        }
+
+        NingBoZhongYiHtmlAnalysisUtil.tableStyle1InsertMap(disTableElement, map);
+        disHandleExt(map);
+
+        //医生签名、医生签名时间
+        Element docSignElement = null, docSignTimeElement = null;
+        if (disTableElement != null) {
+            for (Element disTableElementNt : disTableElement.nextElementSiblings()) {
+                docSignElement = disTableElementNt.selectFirst("image,img");
+                if (docSignElement != null) {
+                    docSignTimeElement = disTableElementNt.nextElementSibling();
+                    break;
+                }
+            }
+        }
+        if (docSignElement != null) {
+//            map.put("医生签名", docSignElement.outerHtml());
+            map.put("医生签名", "暂无");
+        }
+        if (docSignTimeElement != null) {
+            String date = CommonAnalysisUtil.extractDate(NingBoZhongYiHtmlAnalysisUtil.elementLayer1ToStr(docSignTimeElement, false).trim());
+            map.put("医生签名时间", date);
+        }
+
+        //专科检查、辅助检查
+        Element yuElement = new Element("div");
+        if (tgjcTableElement != null) {
+            for (Element tgjcTableElementNt : tgjcTableElement.parent().nextElementSiblings()) {
+                if (StringUtil.isNotBlank(disTableElementId) && tgjcTableElementNt.id().contains(disTableElementId)) {
+                    break;
+                }
+                /*if (tgjcTableElementNt.tagName().equals("table")) {
+                    continue;
+                }*/
+                tgjcTableElementNt.appendTo(yuElement);
+            }
+        }
+        String yuText = NingBoZhongYiHtmlAnalysisUtil.blockDivToStr(yuElement, true).replace("请在下面表格中右键添加诊断", "")
+                /*.replace("体  格  检  查  表 (二)", "")
+                .replace("(补充及专科情况)", "")
+                .replace("辅  助  检  查", "辅助检查:")
+                .replace("诊断:", "")
+                .replace("补充专科情况", "补充专科情况:")
+                .trim()*/;
+        CommonAnalysisUtil.cutByTitles(yuText, Lists.newArrayList("专科检查", "辅助检查"), 0, map);
+
+    }
+
+    //24小时出入院记录、24小时出入院记录(全院)、24小时入出院记录(全院通用)、24小时内入院死亡记录(全院通用)
+    private void analysis24h(Document doc, Map<String, String> map) {
+        String text = NingBoZhongYiHtmlAnalysisUtil.blockDivToStr(doc.selectFirst("body").child(0), false);
+        text = text.substring(text.lastIndexOf("24小时入出院记录姓    名")).replaceFirst("第1页", "");
+        List<String> titles = Lists.newArrayList("姓    名", "家庭住址", "性    别", "工作单位", "年    龄", "身份证号码", "民    族",
+                "联系人(关系)", "职    业", "入院时间", "婚    姻", "死亡时间", "记录时间", "出 生 地", "病史陈述者", "主    诉", "入院情况", "心理评估",
+                "疼痛评估", "营养评估", "功能评估", "入院诊断", "诊疗经过", "死亡原因", "死亡诊断", "出院情况", "出院诊断", "出院计划", "出院医嘱",
+                "出院去向", "医师签名", "书写时间");
+
+        CommonAnalysisUtil.cutByTitles(text, titles, 0, map);
+        CommonAnalysisUtil.processType(map, "出院去向");
+    }
+
+    //原-日间病历入出院记录、日间病历-性早熟
+    private void analysisDay(Document doc, Map<String, String> map) {
+        //个人基础信息table解析
+        NingBoZhongYiHtmlAnalysisUtil.tableStyle1InsertMap(doc.getElementById("table1"), map);
+        //主诉、入院情况等table解析
+        NingBoZhongYiHtmlAnalysisUtil.tableStyle2InsertMap(doc.getElementById("table6"), map);
+        //医生签名、医生签名时间
+        Element docSignElement = null, docSignTimeElement = null;
+        for (Element table6ElementNt : doc.getElementById("table6").parent().nextElementSiblings()) {
+            docSignElement = table6ElementNt.selectFirst("image,img");
+            if (docSignElement != null) {
+                docSignTimeElement = table6ElementNt.nextElementSibling();
+                break;
+            }
+        }
+        if (docSignElement != null) {
+//            map.put("医生签名", docSignElement.outerHtml());
+            map.put("医生签名", "暂无");
+        }
+        if (docSignTimeElement != null) {
+            map.put("医生签名时间", NingBoZhongYiHtmlAnalysisUtil.elementLayer1ToStr(docSignTimeElement, false).trim());
+        }
+    }
+
+    private void disHandleExt(Map<String, String> map) {
+        String[] keys = {"补充诊断", "修正诊断"};
+        String value = null;
+        int index = 0;
+        for (String key : keys) {
+            value = map.get(key);
+            if (StringUtil.isNotBlank(value)) {
+                for (String key_ : keys) {
+                    index = value.indexOf(key_);
+                    if (index > 0) {
+                        map.put(key_, value.substring(index + 5));
+                        map.put(key, value.substring(0, index));
+                    }
+                }
+            }
+        }
+    }
+
+}

+ 71 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiClinicBloodEffectHtmlAnalysis.java

@@ -0,0 +1,71 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Element;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description:
+ * @author: rengb
+ * @time: 2020/9/28 19:41
+ */
+@Slf4j
+public class NingBoZhongYiClinicBloodEffectHtmlAnalysis implements NingBoZhongYiHtmlAnalysis {
+    List<String> titles = Lists.newArrayList("输血前症状", "输血前实验室指标", "输血目的", "输注成分", "输血时间",
+            "开始时间", "结束时间", "输血过程");
+
+    private String modeId = "32";
+
+    @Override
+    public Map<String, String> analysis(String... args) {
+        Map<String, String> map = Maps.newLinkedHashMap();
+        try {
+            String html = args[0];
+            String recTitle = args[1];
+            String recTypeId = args[2];
+            Element bigDivElement = Jsoup.parse(html).selectFirst("body").child(0);
+            analysisGeneral(recTitle,bigDivElement, map);
+            if (map.containsKey("病情记录")) {
+                String content = map.get("病情记录");
+                CommonAnalysisUtil.cutByTitles(content, titles, 0, map);
+            }
+        /*titles.remove(5);
+        titles.forEach(i -> {
+                    if (map.get(i).length() > 2) {
+                        map.put(i, map.get(i).substring(0, map.get(i).length() - 2));
+                    }
+                }
+        );
+
+         */
+            NingBoZhongYiHtmlAnalysisUtil.insertModuleId(modeId, recTypeId, map);
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return map;
+    }
+
+    private void analysisGeneral(String recTitle, Element bigDivElement, Map<String, String> map) {
+        if (bigDivElement.childNodeSize() == 1) {
+            bigDivElement = bigDivElement.child(0);
+        }
+        if (bigDivElement.selectFirst("hr") != null) {
+            bigDivElement.selectFirst("hr").previousElementSiblings().remove();
+        }
+        String text = NingBoZhongYiHtmlAnalysisUtil.blockDivToStr(bigDivElement, true);
+        CommonAnalysisUtil.extractWardInfo(recTitle,text, map);
+        String bqjlText = "病情记录" + map.get("病情记录");
+        List<String> titles = Lists.newArrayList(
+                "病情记录"
+        );
+        titles = CommonAnalysisUtil.sortTitlesNoColon(titles, bqjlText);
+        CommonAnalysisUtil.cutByTitlesNoColon(bqjlText, titles, 0, map);
+    }
+
+}

+ 72 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiClinicalBloodHtmlAnalysis.java

@@ -0,0 +1,72 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Element;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description:
+ * @author: rengb
+ * @time: 2020/9/28 17:56
+ */
+@Slf4j
+public class NingBoZhongYiClinicalBloodHtmlAnalysis implements NingBoZhongYiHtmlAnalysis {
+
+
+    private String modeId = "10";
+
+    @Override
+    public Map<String, String> analysis(String... args) {
+        List<String> titles = Lists.newArrayList("输血前症状", "输血前实验室指标", "输血目的", "输注成分", "输血时间",
+                "开始时间", "结束时间", "输血过程");
+        Map<String, String> map = Maps.newLinkedHashMap();
+        try {
+            String html = args[0];
+            String recTitle = args[1];
+            String recTypeId = args[2];
+            Element bigDivElement = Jsoup.parse(html).selectFirst("body").child(0);
+            analysisGeneral(recTitle,bigDivElement, map);
+            if (map.containsKey("病情记录")) {
+                String content = map.get("病情记录");
+                CommonAnalysisUtil.cutByTitles(content, titles, 0, map);
+            }
+            if (titles.size() > 6) {
+                titles.remove(5);
+            }
+            titles.forEach(i -> {
+                        if (map.get(i).length() > 2) {
+                            map.put(i, map.get(i).substring(0, map.get(i).length() - 2));
+                        }
+                    }
+            );
+            NingBoZhongYiHtmlAnalysisUtil.insertModuleId(modeId, recTypeId, map);
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return map;
+    }
+
+    private void analysisGeneral(String recTitle, Element bigDivElement, Map<String, String> map) {
+        if (bigDivElement.childNodeSize() == 1) {
+            bigDivElement = bigDivElement.child(0);
+        }
+        if (bigDivElement.selectFirst("hr") != null) {
+            bigDivElement.selectFirst("hr").previousElementSiblings().remove();
+        }
+        String text = NingBoZhongYiHtmlAnalysisUtil.blockDivToStr(bigDivElement, true);
+        CommonAnalysisUtil.extractWardInfo(recTitle,text, map);
+        String bqjlText = "病情记录" + map.get("病情记录");
+        List<String> titles = Lists.newArrayList(
+                "病情记录"
+        );
+        titles = CommonAnalysisUtil.sortTitlesNoColon(titles, bqjlText);
+        CommonAnalysisUtil.cutByTitlesNoColon(bqjlText, titles, 0, map);
+    }
+
+}

+ 120 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiConsultationHtmlAnalysis.java

@@ -0,0 +1,120 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.lantone.qc.pub.util.StringUtil;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Document;
+
+import java.util.List;
+import java.util.Map;
+import java.util.stream.Collectors;
+
+/**
+ * @Description:
+ * @author: rengb
+ * @time: 2020/9/12 13:53
+ */
+@Slf4j
+public class NingBoZhongYiConsultationHtmlAnalysis implements NingBoZhongYiHtmlAnalysis {
+
+    private String modeId = "31";
+
+    @Override
+    public Map<String, String> analysis(String... args) {
+        Map<String, String> structureMap = Maps.newLinkedHashMap();
+
+        try {
+            List<String> titles = Lists.newArrayList("姓名", "性别", "出生日期", "科别", "病区", "床号", "住院号",
+                    "会诊类型", "被邀医院", "被邀科室", "被邀医师", "申请时间", "患者病情及诊疗经过、申请会诊的理由及目的", "申请会诊科别",
+                    "被邀会诊科别", "申请会诊医师", "会诊意见", "会诊时间", "科主任", "会诊到达时间", "查体", "会诊建议",
+                    "会诊诊断", "由受邀医生填写,本次会诊是否必要","会诊科室", "会诊医师", "外院会诊医师所在医疗机构名称", "会诊医师所在医疗机构名称");
+            String html = args[0];
+            String recTitle = args[1];
+            String recTypeId = args[2];
+            String htmlContent = null;
+            Document doc = Jsoup.parse(html);
+            if ("外院专家会诊申请单".equals(recTitle)) {
+                htmlContent = CommonAnalysisUtil.html2String(html);
+                if (StringUtil.isNotBlank(htmlContent)) {
+                    htmlContent = htmlContent.replaceAll("[   ]", " ").replace("第1页", "");
+                    CommonAnalysisUtil.html2StructureMap(titles, htmlContent, structureMap);
+                }
+            } else if ("协定方会诊".equals(recTitle)) {
+                htmlContent = NingBoZhongYiHtmlAnalysisUtil.blockDivToStr(doc.selectFirst("body").child(0), true);
+                if (StringUtil.isNotBlank(htmlContent)) {
+                    htmlContent = htmlContent.replaceAll("[   ]", " ").replace("第1页", "");
+                    CommonAnalysisUtil.html2StructureMap(titles, htmlContent, structureMap);
+                }
+                if (StringUtil.isNotBlank(structureMap.get("会诊时间"))) {
+                    String[] strArr = structureMap.get("会诊时间").split(" ");
+                    structureMap.put("会诊意见", strArr[strArr.length - 1]);
+                    structureMap.put("会诊时间", strArr[0]);
+                }
+                CommonAnalysisUtil.extractDateByTitle(structureMap, "申请时间");
+            } else if ("MDT会诊申请表".equals(recTitle) || "新-MDT会诊三合一".equals(recTitle)) {
+                titles = Lists.newArrayList("姓名", "性别", "出生日期", "联系电话",
+                        "申请科室", "入院/首诊时间", "住院号", "病情概述(含主诉、病史、诊断、诊治过程等)", "拟申请MDT时间、地点",
+                        "拟请MDT参加科室", "MDT目的", "申请人签名", "申请递交时间", "科主任签字", "专家诊治建议", "专家科室", "签名",
+                        "填写时间", "主持科室小结(MDT的最终诊治决议)", "科主任(主持人)签名", "记录人(主管医师)签字", "日期");
+                htmlContent = CommonAnalysisUtil.html2String(html);
+                if (StringUtil.isNotBlank(htmlContent)) {
+                    htmlContent = htmlContent.replaceAll("[   ]", " ").replace("住院/门诊号", "").replace("第1页", "");
+                    StringBuffer sbf = new StringBuffer();
+                    List<String> distinctText = Lists.newArrayList(htmlContent.split(" ")).stream().distinct().collect(Collectors.toList());
+                    for (String text : distinctText) {
+                        sbf.append(text).append(" ");
+                    }
+                    CommonAnalysisUtil.html2StructureMapNoColon(titles, sbf.toString(), structureMap);
+                }
+                if (StringUtil.isNotBlank(structureMap.get("主持科室小结(MDT的最终诊治决议)"))) {
+                    String[] valueArray = structureMap.get("主持科室小结(MDT的最终诊治决议)").split(" ");
+                    structureMap.put("主持科室小结(MDT的最终诊治决议)", valueArray[1]);
+                    String v = valueArray[2];
+                    String[] vArr = v.split(":");
+                    if (vArr.length > 1) {
+                        structureMap.put(vArr[0], vArr[1]);
+                    }
+                }
+            } else if ("(外地专家)会诊邀请函".equals(recTitle)) {
+                titles = Lists.newArrayList("姓名", "出生年月", "病区", "床位", "住院号", "病情摘要", "会诊日期", "被邀医师", "专业",
+                        "职称", "单位", "会诊费用", "会诊科室", "医师签名", "医生签名", "科主任 签名", "患方意见", "签字", "外来专家 意见", "签字",
+                        "邀请医院(钉钉审批后盖章)");
+                htmlContent = CommonAnalysisUtil.html2String(html);
+                if (StringUtil.isNotBlank(htmlContent)) {
+                    htmlContent = htmlContent.replaceAll("[   ]", " ").replace("第1页", "").replace("年   月   日   时   分", "");
+                    CommonAnalysisUtil.html2StructureMapNoColon(titles, htmlContent, structureMap);
+                }
+                if (structureMap.containsKey("外来专家意见")) {
+                    structureMap.put("外来专家意见", structureMap.get("外来专家意见").replaceAll("签字:", ""));
+                }
+                if (structureMap.containsKey("被邀医师")) {
+                    structureMap.put("会诊医师", structureMap.get("被邀医师"));
+                }
+
+            } else {
+                htmlContent = NingBoZhongYiHtmlAnalysisUtil.blockDivToStr(doc.selectFirst("body").child(0), true);
+                //htmlContent = CommonAnalysisUtil.html2String(html);
+                if (StringUtil.isNotBlank(htmlContent)) {
+                    htmlContent = htmlContent.replaceAll("[   ]", " ").replace("第1页", "");
+                    CommonAnalysisUtil.html2StructureMap(titles, htmlContent, structureMap);
+                }
+            }
+            if (structureMap.containsKey("会诊到达时间")) {
+                String arriveDateStr = CommonAnalysisUtil.extractDate(structureMap.get("会诊到达时间"));
+                if (StringUtil.isNotBlank(arriveDateStr)) {
+                    structureMap.put("会诊意见", structureMap.get("会诊到达时间").replace(arriveDateStr, "").trim());
+                    structureMap.put("会诊到达时间", arriveDateStr);
+                }
+            }
+            CommonAnalysisUtil.processType(structureMap, "会诊类型");
+            NingBoZhongYiHtmlAnalysisUtil.insertModuleId(modeId, recTypeId, structureMap);
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return structureMap;
+    }
+
+}

+ 57 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiConsultationRecordHtmlAnalysis.java

@@ -0,0 +1,57 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Element;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description:
+ * @author: rengb
+ * @time: 2020/9/28 20:12
+ */
+@Slf4j
+public class NingBoZhongYiConsultationRecordHtmlAnalysis implements NingBoZhongYiHtmlAnalysis {
+
+    private String modeId = "7";
+
+    @Override
+    public Map<String, String> analysis(String... args) {
+        Map<String, String> map = Maps.newLinkedHashMap();
+        try {
+            String html = args[0];
+            String recTitle = args[1];
+            String recTypeId = args[2];
+            NingBoZhongYiHtmlAnalysisUtil.tableStyle1InsertMap(Jsoup.parse(html).getElementById("table1_1"), map);
+            Element bigDivElement = Jsoup.parse(html).selectFirst("body").child(0);
+            analysisGeneral(recTitle,bigDivElement, map);
+            NingBoZhongYiHtmlAnalysisUtil.insertModuleId(modeId, recTypeId, map);
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return map;
+    }
+
+    private void analysisGeneral(String recTitle, Element bigDivElement, Map<String, String> map) {
+        if (bigDivElement.childNodeSize() == 1) {
+            bigDivElement = bigDivElement.child(0);
+        }
+        if (bigDivElement.selectFirst("hr") != null) {
+            bigDivElement.selectFirst("hr").previousElementSiblings().remove();
+        }
+        String text = NingBoZhongYiHtmlAnalysisUtil.blockDivToStr(bigDivElement, true);
+        CommonAnalysisUtil.extractWardInfo(recTitle,text, map);
+        String bqjlText = "病情记录" + map.get("病情记录").replace("请在此填写会诊处理意见","").replace("会诊回复时间","");
+        List<String> titles = Lists.newArrayList(
+                "病情记录","答复","日期时间"
+        );
+        titles = CommonAnalysisUtil.sortTitlesNoColon(titles, bqjlText);
+        CommonAnalysisUtil.cutByTitlesNoColon(bqjlText, titles, 0, map);
+    }
+
+}

+ 56 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiCrisisValueReportHtmlAnalysis.java

@@ -0,0 +1,56 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Element;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description:
+ * @author: rengb
+ * @time: 2020/9/28 19:48
+ */
+@Slf4j
+public class NingBoZhongYiCrisisValueReportHtmlAnalysis implements NingBoZhongYiHtmlAnalysis {
+
+    private String modeId = "23";
+
+    @Override
+    public Map<String, String> analysis(String... args) {
+        Map<String, String> map = Maps.newLinkedHashMap();
+        try {
+            String html = args[0];
+            String recTitle = args[1];
+            String recTypeId = args[2];
+            Element bigDivElement = Jsoup.parse(html).selectFirst("body").child(0);
+            analysisGeneral(recTitle,bigDivElement, map);
+            NingBoZhongYiHtmlAnalysisUtil.insertModuleId(modeId, recTypeId, map);
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return map;
+    }
+
+    private void analysisGeneral(String recTitle, Element bigDivElement, Map<String, String> map) {
+        if (bigDivElement.childNodeSize() == 1) {
+            bigDivElement = bigDivElement.child(0);
+        }
+        if (bigDivElement.selectFirst("hr") != null) {
+            bigDivElement.selectFirst("hr").previousElementSiblings().remove();
+        }
+        String text = NingBoZhongYiHtmlAnalysisUtil.blockDivToStr(bigDivElement, true);
+        CommonAnalysisUtil.extractWardInfo(recTitle,text, map);
+        String bqjlText = "病情记录" + map.get("病情记录");
+        List<String> titles = Lists.newArrayList(
+                "病情记录"
+        );
+        titles = CommonAnalysisUtil.sortTitlesNoColon(titles, bqjlText);
+        CommonAnalysisUtil.cutByTitlesNoColon(bqjlText, titles, 0, map);
+    }
+
+}

+ 49 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiCriticallyIllNoticeHtmlAnalysis.java

@@ -0,0 +1,49 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.lantone.qc.pub.util.StringUtil;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Document;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description: 病危(重)通知单html解析
+ * @author: HUJING
+ * @time: 2020/9/14 15:28
+ */
+@Slf4j
+public class NingBoZhongYiCriticallyIllNoticeHtmlAnalysis implements NingBoZhongYiHtmlAnalysis {
+
+    private String modeId = "25";
+
+    @Override
+    public Map<String, String> analysis(String... args) {
+        Map<String, String> structureMap = Maps.newLinkedHashMap();
+
+        try {
+            List<String> titles = Lists.newArrayList("姓名", "性别", "出生日期", "科别", "病区", "床号", "住院号",
+                    "临床诊断", "病情摘要", "主要症状", "体格检查", "辅助检查", "告知医师签名",
+                    "告知时间", "患方意见", "患方签名", "手印说明", "与患者关系", "签字时间");
+            String html = args[0];
+            String recTitle = args[1];
+            String recTypeId = args[2];
+            Document doc = Jsoup.parse(html);
+            String htmlContent = NingBoZhongYiHtmlAnalysisUtil.blockDivToStr(doc.selectFirst("body").child(0), true);
+            if (StringUtil.isNotBlank(htmlContent)) {
+                htmlContent = htmlContent.replaceAll("[   ]", " ");
+                CommonAnalysisUtil.html2StructureMap(titles, htmlContent, structureMap);
+            }
+            CommonAnalysisUtil.extractDateByTitle(structureMap, "告知时间");
+            NingBoZhongYiHtmlAnalysisUtil.insertModuleId(modeId, recTypeId, structureMap);
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return structureMap;
+    }
+
+}

+ 56 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiDeathCaseDiscussHtmlAnalysis.java

@@ -0,0 +1,56 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Document;
+import org.jsoup.nodes.Element;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description:
+ * @author: rengb
+ * @time: 2020/9/17 14:27
+ */
+@Slf4j
+public class NingBoZhongYiDeathCaseDiscussHtmlAnalysis implements NingBoZhongYiHtmlAnalysis {
+
+    private String modeId = "3";
+
+    @Override
+    public Map<String, String> analysis(String... args) {
+        Map<String, String> map = Maps.newLinkedHashMap();
+        try {
+            String html = args[0];
+            String recTypeId = args[2];
+            Document doc = Jsoup.parse(html);
+            Element bigDivElement = doc.selectFirst("body").child(0);
+            NingBoZhongYiHtmlAnalysisUtil.tableStyle1InsertMap(doc.getElementById("table1"), map);
+            /*bigDivElement.child(0).lastElementSibling().remove();
+            map.put("医生签名时间", NingBoZhongYiHtmlAnalysisUtil.elementLayer1ToStr(bigDivElement.child(0).lastElementSibling(), false));
+            bigDivElement.child(0).lastElementSibling().remove();*/
+
+            String text = NingBoZhongYiHtmlAnalysisUtil.blockDivToStr(bigDivElement, false).replace("病情变化、诊治、抢救情况", "");
+            List<String> titles = Lists.newArrayList("姓名", "床号", "住院号", "性别", "年龄", "婚姻", "地址",
+                    "入院日期", "死亡时间", "入院诊断", "讨论时间", "讨论主持人", "诊疗经过", "参加者",
+                    "发言记录(包括病史摘要、治疗抢救过程、讨论目的、讨论意见及结论)", "病史摘要(经管医师汇报病史)",
+                    "讨论目的", "讨论意见", "主持人小结", "死亡原因", "死亡诊断", "科主任(签名)", "记录者(签名)");
+            titles = CommonAnalysisUtil.sortTitles(titles, text);
+            CommonAnalysisUtil.cutByTitlesNoColon(text, titles, 0, map);
+            NingBoZhongYiHtmlAnalysisUtil.mapValueRemoveStartColon(map);
+            map.put("记录时间", map.get("记录者(签名)").replace("—", ""));
+            map.put("记录者(签名)", map.get("记录者(签名)").replace("时间", ""));
+            map.put("讨论意见", map.get("讨论意见").replace("讨论意见", ""));
+            map.put("主持人小结", map.get("主持人小结").replace("主持人小结", ""));
+            NingBoZhongYiHtmlAnalysisUtil.insertModuleId(modeId, recTypeId, map);
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return map;
+    }
+
+}

+ 51 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiDeathRecordHtmlAnalysis.java

@@ -0,0 +1,51 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.lantone.qc.pub.util.StringUtil;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Document;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description: 死亡记录html解析
+ * @author: HUJING
+ * @time: 2020/9/14 15:41
+ */
+@Slf4j
+public class NingBoZhongYiDeathRecordHtmlAnalysis implements NingBoZhongYiHtmlAnalysis {
+
+    private String modeId = "24";
+
+    @Override
+    public Map<String, String> analysis(String... args) {
+        Map<String, String> structureMap = Maps.newLinkedHashMap();
+        try {
+            List<String> titles = Lists.newArrayList("性别", "年龄", "婚姻", "入院日期", "死亡时间", "入院情况", "入院诊断",
+                    "诊疗经过(重点记录病情演变、抢救经过)", "诊疗经过", "死亡原因", "死亡诊断", "医师签字", "医生签名", "记录时间");
+            String html = args[0];
+            String recTitle = args[1];
+            String recTypeId = args[2];
+            Document doc = Jsoup.parse(html);
+            NingBoZhongYiHtmlAnalysisUtil.tableStyle1InsertMap(doc.getElementById("table1"), structureMap);
+            String htmlContent = NingBoZhongYiHtmlAnalysisUtil.blockDivToStr(doc.selectFirst("body").child(0), false);
+            if (StringUtil.isNotBlank(htmlContent)) {
+                htmlContent = htmlContent.replaceAll("[   ]", " ");
+                CommonAnalysisUtil.html2StructureMap(titles, htmlContent, structureMap);
+            }
+            if (CommonAnalysisUtil.extractDate(structureMap.get("医生签名")) != null) {
+                structureMap.put("记录时间", CommonAnalysisUtil.extractDate(structureMap.get("医生签名")));
+            }
+            structureMap.put("医生签名", structureMap.get("医生签名").replace("时间", ""));
+            CommonAnalysisUtil.extractDateByTitle(structureMap, "记录时间");
+            NingBoZhongYiHtmlAnalysisUtil.insertModuleId(modeId, recTypeId, structureMap);
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return structureMap;
+    }
+}

+ 92 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiDifficultCaseDiscussHtmlAnalysis.java

@@ -0,0 +1,92 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.lantone.qc.pub.util.StringUtil;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Document;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description: 疑难、危重病例讨论记录html解析
+ * @author: HUJING
+ * @time: 2020/9/14 15:41
+ */
+@Slf4j
+public class NingBoZhongYiDifficultCaseDiscussHtmlAnalysis implements NingBoZhongYiHtmlAnalysis {
+
+    private String modeId = "19";
+
+    @Override
+    public Map<String, String> analysis(String... args) {
+        Map<String, String> structureMap = Maps.newLinkedHashMap();
+        try {
+            List<String> titles = Lists.newArrayList("姓名", "性别", "出生日期", "科别", "病区", "床号",
+                    "住院号", "年龄", "床位", "住院号", "住址(单位)", "住址(或单位)", "讨论日期", "讨论地点",
+                    "讨论主持人", "参加人员", "参加讨论人", "病史简要", "讨论目的", "讨论意见", "主持人小结", "下一步方案",
+                    "具体讨论意见", "主持人小结意见", "主持人小结意见/讨论结论", "主持人签名", "记录医生签名", "记录者(签名)", "科主任(签名)");
+            String html = args[0];
+            String recTitle = args[1];
+            String recTypeId = args[2];
+            Document doc = Jsoup.parse(html);
+            NingBoZhongYiHtmlAnalysisUtil.tableStyle1InsertMap(doc.getElementById("table1"), structureMap);
+            doc.selectFirst("body").child(0).getElementById("table1").remove();
+            String htmlContent = NingBoZhongYiHtmlAnalysisUtil.blockDivToStr(doc.selectFirst("body").child(0), true);
+            if (StringUtil.isNotBlank(htmlContent)) {
+                htmlContent = htmlContent.replaceAll("[   ]", " ").replace("第一页", "").replace("发言记录(包括病史简要、讨论意见及结论):", "");
+                CommonAnalysisUtil.html2StructureMap(titles, htmlContent, structureMap);
+            }
+            CommonAnalysisUtil.extractDateByTitle(structureMap, "告知时间");
+            removeLast(structureMap);
+            if (structureMap.containsKey("住院号")) {
+                String date = CommonAnalysisUtil.extractDate(structureMap.get("住院号"));
+                if (StringUtil.isNotBlank(date)) {
+                    structureMap.put("时间", date);
+                    structureMap.put("住院号", structureMap.get("住院号").replace(date, "").replace("\n", ""));
+
+                }
+            }
+            if (structureMap.containsKey("记录者(签名)")) {
+                    structureMap.put("记录医生", structureMap.get("记录者(签名)").replace(" ",""));
+            }
+            if (structureMap.containsKey("科主任(签名)")) {
+                String date1 = CommonAnalysisUtil.NBZYExtractDate(structureMap.get("科主任(签名)").replace(" ", ""));
+                if (StringUtil.isNotBlank(date1)) {
+                    structureMap.put("科主任签名", structureMap.get("科主任(签名)").replace(" ","").replace(date1, ""));
+                }else{
+                    structureMap.put("科主任签名", structureMap.get("科主任(签名)").replace(" ","").replace("年月日", ""));
+                }
+            }
+            NingBoZhongYiHtmlAnalysisUtil.insertModuleId(modeId, recTypeId, structureMap);
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return structureMap;
+    }
+
+    /**
+     * 去除value中最后的逗号
+     *
+     * @param structureMap
+     */
+    private void removeLast(Map<String, String> structureMap) {
+        for (Map.Entry<String, String> entry : structureMap.entrySet()) {
+            structureMap.put(entry.getKey(), findLast(entry.getValue()));
+        }
+    }
+
+    private String findLast(String value) {
+        if (StringUtil.isNotBlank(value)) {
+            if (value.lastIndexOf(",") != value.length() - 1) {
+                return value;
+            }
+            value = value.substring(0, value.length() - 1);
+            findLast(value);
+        }
+        return value;
+    }
+}

+ 56 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiDutyShiftSystemHtmlAnalysis.java

@@ -0,0 +1,56 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Element;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description:
+ * @author: rengb
+ * @time: 2020/9/28 20:00
+ */
+@Slf4j
+public class NingBoZhongYiDutyShiftSystemHtmlAnalysis implements NingBoZhongYiHtmlAnalysis {
+
+    private String modeId = "9";
+
+    @Override
+    public Map<String, String> analysis(String... args) {
+        Map<String, String> map = Maps.newLinkedHashMap();
+        try {
+            String html = args[0];
+            String recTitle = args[1];
+            String recTypeId = args[2];
+            Element bigDivElement = Jsoup.parse(html).selectFirst("body").child(0);
+            analysisGeneral(recTitle,bigDivElement, map);
+            NingBoZhongYiHtmlAnalysisUtil.insertModuleId(modeId, recTypeId, map);
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return map;
+    }
+
+    private void analysisGeneral(String recTitle, Element bigDivElement, Map<String, String> map) {
+        if (bigDivElement.childNodeSize() == 1) {
+            bigDivElement = bigDivElement.child(0);
+        }
+        if (bigDivElement.selectFirst("hr") != null) {
+            bigDivElement.selectFirst("hr").previousElementSiblings().remove();
+        }
+        String text = NingBoZhongYiHtmlAnalysisUtil.blockDivToStr(bigDivElement, true);
+        CommonAnalysisUtil.extractWardInfo(recTitle,text, map);
+        String bqjlText = "病情记录" + map.get("病情记录");
+        List<String> titles = Lists.newArrayList(
+                "病情记录"
+        );
+        titles = CommonAnalysisUtil.sortTitlesNoColon(titles, bqjlText);
+        CommonAnalysisUtil.cutByTitlesNoColon(bqjlText, titles, 0, map);
+    }
+
+}

+ 59 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiFirstCourseRecordHtmlAnalysis.java

@@ -0,0 +1,59 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.lantone.qc.pub.util.StringUtil;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Document;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description:
+ * @author: HUJING
+ * @time: 2020/9/9 11:24
+ */
+@Slf4j
+public class NingBoZhongYiFirstCourseRecordHtmlAnalysis implements NingBoZhongYiHtmlAnalysis {
+
+    private String modeId = "2";
+
+    @Override
+    public Map<String, String> analysis(String... args) {
+        Map<String, String> structureMap = Maps.newLinkedHashMap();
+        try {
+            List<String> titles = Lists.newArrayList("病例特点", "拟诊讨论", "中医辨病辨证依据", "中医鉴别诊断", "西医诊断依据", "西医鉴别诊断", "初步诊断", "病情评估", "诊疗计划");
+            String html = args[0];
+            String recTitle = args[1];
+            Document doc = Jsoup.parse(html);
+            String htmlContent = NingBoZhongYiHtmlAnalysisUtil.blockDivToStr(doc.selectFirst("body").child(0), true);
+            if (StringUtil.isNotBlank(htmlContent)) {
+                String[] lines = htmlContent.split("\n\n");
+                if (StringUtil.isNotBlank(lines[0])) {
+                    String date = CommonAnalysisUtil.extractDate(lines[0]);
+                    if (StringUtil.isNotBlank(date)) {
+                        structureMap.put("时间", date);
+                        lines[0] = lines[0].replace(date, "");
+                    }
+                }
+                titles = CommonAnalysisUtil.sortTitles(titles, htmlContent);
+                CommonAnalysisUtil.cutByTitles(htmlContent, titles, 0, structureMap);
+                structureMap.put("诊断依据", "中医辨病辨证依据:" + structureMap.get("中医辨病辨证依据") + "西医诊断依据:" + structureMap.get("西医诊断依据"));
+                structureMap.put("鉴别诊断", "中医鉴别诊断:" + structureMap.get("中医鉴别诊断") + "西医鉴别诊断:" + structureMap.get("西医鉴别诊断"));
+
+            }
+
+            NingBoZhongYiHtmlAnalysisUtil.insertModuleId(modeId, recTitle, structureMap);
+            //        CommonAnalysisUtil.extractDateByTitle(structureMap, "时间");
+            //        structureMap.forEach((k,v)-> System.out.println(k + "------" + v));
+            //        structureMap.put("rec_title=", "107");
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return structureMap;
+    }
+
+}

+ 14 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiHtmlAnalysis.java

@@ -0,0 +1,14 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import java.util.Map;
+
+/**
+ * @Description: 北仑html解析
+ * @author: rengb
+ * @time: 2020/9/9 11:26
+ */
+public interface NingBoZhongYiHtmlAnalysis {
+
+    Map<String, String> analysis(String... args);
+
+}

+ 243 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiHtmlAnalysisUtil.java

@@ -0,0 +1,243 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import com.google.common.collect.Lists;
+import com.lantone.qc.dbanaly.util.ModuleMappingUtil;
+import com.lantone.qc.pub.util.StringUtil;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import org.jsoup.nodes.Element;
+import org.jsoup.select.Elements;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description:
+ * @author: rengb
+ * @time: 2020/9/15 16:31
+ */
+public class NingBoZhongYiHtmlAnalysisUtil {
+
+    /**
+     * table样式:key和value在同一个td中,以冒号分开;保留换行
+     *
+     * @param tableElement
+     * @param map
+     */
+    public static void tableStyle1InsertMap(Element tableElement, Map<String, String> map) {
+        if (tableElement == null || map == null) {
+            return;
+        }
+        List<Element> tdElements = Lists.newArrayList();
+        tableElement.selectFirst("tbody").children().forEach(trElement -> {
+            trElement.children().forEach(tdElement -> {
+                tdElements.add(tdElement);
+            });
+        });
+        String tdText = null;
+        int tdMhIndex = 0;
+        for (Element tdElement : tdElements) {
+            if (tdElement.childNodeSize() == 0) {
+                continue;
+            }
+            tdText = blockDivToStr(tdElement.child(0), true);
+            if (tdText.endsWith("\n")) {
+                tdText = tdText.substring(0, tdText.length() - 1);
+            }
+            if (StringUtil.isBlank(tdText)) {
+                continue;
+            }
+            tdMhIndex = tdText.indexOf(":");
+            if (tdMhIndex == -1) {
+                tdMhIndex = tdText.indexOf(":");
+            }
+            if (tdMhIndex < 1) {
+                continue;
+            }
+            if (tdText.contains("姓    名") && tdText.contains("年    龄")) {
+                multiColonResolve(tdMhIndex, tdText, "年    龄", map);
+            } else if (tdText.contains("姓    名") && tdText.contains("年   龄")) {
+                multiColonResolve(tdMhIndex, tdText, "年   龄", map);
+            } else if (tdText.contains("姓    名") && tdText.contains("年  龄")) {
+                multiColonResolve(tdMhIndex, tdText, "年  龄", map);
+            } else if (tdText.contains("姓    名") && tdText.contains("年 龄")) {
+                multiColonResolve(tdMhIndex, tdText, "年 龄", map);
+            } else if (tdText.contains("产前检查") && tdText.contains("孕/产次")) {
+                multiColonResolve(tdMhIndex, tdText, "孕/产次", map);
+            } else if (tdText.contains("末次月经") && tdText.contains("预产期")) {
+                multiColonResolve(tdMhIndex, tdText, "预产期", map);
+            } else if (tdText.contains("中医诊断:") && tdText.contains("西医诊断:")) {
+                List<String> titles = Lists.newArrayList("中医诊断", "西医诊断");
+                CommonAnalysisUtil.cutByTitles(tdText, titles, 0, map);
+                map.put("初步诊断", "中医诊断:" + map.get("中医诊断") + "西医诊断:" + map.get("西医诊断"));
+            } else {
+                map.put(
+                        StringUtil.removeBlank(tdText.substring(0, tdMhIndex)),
+                        tdText.length() - 1 <= tdMhIndex ? "" : tdText.substring(tdMhIndex + 1)
+                );
+            }
+        }
+    }
+
+    /**
+     * 取得多个字段时,分别存储
+     *
+     * @param tdText
+     * @param text
+     */
+    public static void multiColonResolve(int tdMhIndex, String tdText, String text, Map<String, String> map) {
+        String firstText = tdText.split(text)[0];
+        map.put(
+                StringUtil.removeBlank(firstText.substring(0, tdMhIndex)),
+                firstText.length() - 1 <= tdMhIndex ? "" : firstText.substring(tdMhIndex + 1)
+        );
+        String secondText = tdText.split(text)[1];
+        secondText = secondText.replace(":", "");
+        secondText = secondText.replace(":", "");
+        map.put(StringUtil.removeBlank(text), secondText);
+    }
+
+    /**
+     * table样式:td两两配对,一个key,一个value;不保留换行
+     *
+     * @param tableElement
+     * @param map
+     */
+    public static void tableStyle2InsertMap(Element tableElement, Map<String, String> map) {
+        if (tableElement == null || map == null) {
+            return;
+        }
+        List<Element> tdElements = Lists.newArrayList();
+        tableElement.selectFirst("tbody").children().forEach(trElement -> {
+            if (trElement.childNodeSize() != 2) {
+                return;
+            }
+            trElement.children().forEach(tdElement -> {
+                tdElements.add(tdElement);
+            });
+        });
+        int index = 0;
+        String key = null, value = null, text = null;
+        for (Element tdElement : tdElements) {
+            if (tdElement.childNodeSize() == 0) {
+                text = "";
+            } else {
+                text = blockDivToStr(tdElement.child(0), false);
+            }
+            if (index % 2 == 0) {
+                key = text.replaceAll("[:: ]", "");
+            }
+            if (index % 2 == 1) {
+                value = text;
+                if (StringUtil.isNotBlank(key)) {
+                    map.put(key, value);
+                }
+            }
+            index++;
+        }
+    }
+
+    /**
+     * 一个大的块状div下包含很多行行状div
+     *
+     * @param divElement
+     * @param isLineBreak 是否保留换行
+     * @return
+     */
+    public static String blockDivToStr(Element divElement, boolean isLineBreak) {
+        if (divElement == null) {
+            return "";
+        }
+        StringBuffer sbf = new StringBuffer();
+        for (Element childElement : divElement.children()) {
+            if (isLineBreak) {
+                sbf.append(elementLayer1ToStr(childElement, false)).append("\n");
+            } else {
+                sbf.append(elementLayer1ToStr(childElement, false).trim());
+            }
+        }
+        return sbf.toString();
+    }
+
+    /**
+     * 标签仅遍历第一子层级后转字符串
+     *
+     * @param element
+     * @param isLineBreak 是否保留换行
+     * @return
+     */
+    public static String elementLayer1ToStr(Element element, boolean isLineBreak) {
+        if (element == null) {
+            return "";
+        }
+        StringBuffer sbf = new StringBuffer();
+        List<Element> elements = Lists.newArrayList();
+        Elements childElements = element.children();
+        if (childElements.size() == 0) {
+            elements.add(element);
+        }
+        for (Element childElement : childElements) {
+            elements.add(childElement);
+        }
+        for (Element childElement : elements) {
+            if (childElement.tagName().equals("img") || childElement.tagName().equals("image")) {
+                //                sbf.append(childElement.outerHtml());
+                sbf.append("—");
+            } else {
+                sbf.append(childElement.text());
+            }
+            if (isLineBreak) {
+                sbf.append("\n");
+            }
+        }
+        String sbfString = removeSex(sbf.toString().replaceAll(" ", " "));
+        return sbfString;
+    }
+
+    /**
+     * 查询并插入页面模板id
+     *
+     * @param modeId
+     * @param recTitle
+     * @param map
+     */
+    public static void insertModuleId(String modeId, String recTitle, Map<String, String> map) {
+        if ((StringUtil.isBlank(modeId) && StringUtil.isBlank(recTitle)) || map == null) {
+            return;
+        }
+        String moduleId = ModuleMappingUtil.getHtmlDataTypeModuleId(recTitle);
+        if (StringUtil.isBlank(moduleId)) {
+            moduleId = ModuleMappingUtil.getStandardModuleId(modeId);
+        }
+        map.put("mode_id", moduleId);
+    }
+
+    /**
+     * map中有的value以冒号开头,用此方法来去掉冒号
+     *
+     * @param map
+     */
+    public static void mapValueRemoveStartColon(Map<String, String> map) {
+        if (map == null) {
+            return;
+        }
+        map.keySet().forEach(key -> {
+            if (map.get(key).startsWith(":") || map.get(key).startsWith(":")) {
+                map.put(key, map.get(key).replaceFirst("[::]", ""));
+            }
+        });
+    }
+
+    /**
+     * 北仑:入院记录中性别取得去除"性"
+     * e.g.(性    别:男性 ->性    别:男)
+     *
+     * @param sbfString
+     */
+    public static String removeSex(String sbfString) {
+        if (sbfString.contains("性    别:")) {
+            sbfString = sbfString.substring(0, sbfString.length() - 1);
+        }
+        return sbfString;
+    }
+
+}

+ 64 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiLeaveHospitalHtmlAnalysis.java

@@ -0,0 +1,64 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.lantone.qc.pub.util.StringUtil;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Document;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description:
+ * @author: HUJING
+ * @time: 2020/9/9 11:24
+ */
+@Slf4j
+public class NingBoZhongYiLeaveHospitalHtmlAnalysis implements NingBoZhongYiHtmlAnalysis {
+
+    private String modeId = "5";
+
+    @Override
+    public Map<String, String> analysis(String... args) {
+        Map<String, String> structureMap = Maps.newLinkedHashMap();
+        try {
+            List<String> titles = Lists.newArrayList("姓名", "出生年月", "性别", "年龄 ", "出生日期", "科室", "病区", "床位", "床号", "住院号 ", "住院号",
+                    "入院时间", "出院日期", "地址 ", "住院天数", "婚姻", "入院诊断", "出院诊断", "分娩日期", "分娩方式", "手术指征",
+                    "入院情况", "诊治经过", "入院后检查化验结果", "入院后化验检查结果", "诊疗经过", "治疗结果", "出院计划", "病理检查结果", "出院情况", "婴儿情况",
+                    "治疗效果", "出院医嘱", "医师签名", "日期", "病理切片", "X光拍片", "MRI", "C  T", "其  它", "主治医师", "住院医师", "住院重要检查化验结果", "医生签名");
+            String html = args[0];
+            String recTitle = args[1];
+            String recTypeId = args[2];
+            Document doc = Jsoup.parse(html);
+            NingBoZhongYiHtmlAnalysisUtil.tableStyle1InsertMap(doc.getElementById("table1"), structureMap);
+            doc.selectFirst("body").child(0).getElementById("table1").remove();
+            String htmlContent = NingBoZhongYiHtmlAnalysisUtil.blockDivToStr(doc.selectFirst("body").child(0), true);
+            if (StringUtil.isNotBlank(htmlContent)) {
+                htmlContent = htmlContent.replace("提示信息:诊治经过、出院情况和出院医嘱可通过右键选择专科知识库进行插入", "");
+                htmlContent = htmlContent.replaceAll("[   ]", " ").replace("第1页", "");
+                htmlContent = htmlContent.replace("\n", "");
+                List<String> sortTitles = CommonAnalysisUtil.sortTitles(titles, htmlContent.replace("复诊时间", ""));
+                sortTitles.add("时间");
+                CommonAnalysisUtil.cutByTitles(htmlContent, sortTitles, 0, structureMap);
+            }
+            if (StringUtil.isNotBlank(CommonAnalysisUtil.extractDate(structureMap.get("出院日期")))) {
+                structureMap.put("住院天数", structureMap.get("出院日期").replace(CommonAnalysisUtil.extractDate(structureMap.get("出院日期")), ""));
+                structureMap.put("出院日期", CommonAnalysisUtil.extractDate(structureMap.get("出院日期")));
+            }
+            if (structureMap.containsKey("出院诊断") && structureMap.get("出院诊断").contains("入院情况")) {
+                String discharge = structureMap.get("出院诊断");
+                int index = discharge.indexOf("入院情况");
+                structureMap.put("出院诊断", discharge.substring(0, index));
+                structureMap.put("入院情况", discharge.substring(index + 4));
+            }
+            CommonAnalysisUtil.extractDateByTitle(structureMap, "时间");
+            NingBoZhongYiHtmlAnalysisUtil.insertModuleId(modeId, recTypeId, structureMap);
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return structureMap;
+    }
+}

+ 62 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiOperationHtmlAnalysis.java

@@ -0,0 +1,62 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Element;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description:
+ * @author: rengb
+ * @time: 2020/9/28 14:56
+ */
+@Slf4j
+public class NingBoZhongYiOperationHtmlAnalysis implements NingBoZhongYiHtmlAnalysis {
+
+    private String modeId = "18";
+
+    @Override
+    public Map<String, String> analysis(String... args) {
+        Map<String, String> map = Maps.newLinkedHashMap();
+        try {
+            String html = args[0];
+            String recTitle = args[1];
+            String recTypeId = args[2];
+            Element bigDivElement = Jsoup.parse(html).selectFirst("body").child(0);
+            analysisGeneral(recTitle, bigDivElement, map);
+            CommonAnalysisUtil.makeEmpty(map, "医生签名");
+            NingBoZhongYiHtmlAnalysisUtil.insertModuleId(modeId, recTypeId, map);
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return map;
+    }
+
+    private void analysisGeneral(String recTitle, Element bigDivElement, Map<String, String> map) {
+        if (bigDivElement.childNodeSize() == 1) {
+            bigDivElement = bigDivElement.child(0);
+        }
+        if (bigDivElement.selectFirst("hr") != null) {
+            bigDivElement.selectFirst("hr").previousElementSiblings().remove();
+        }
+        String text = NingBoZhongYiHtmlAnalysisUtil.blockDivToStr(bigDivElement, true);
+        CommonAnalysisUtil.extractWardInfo(recTitle, text, map);
+        String bqjlText = "病情记录" + map.get("病情记录")
+                .replace("提醒:有创诊疗操作记录内容包括操作名称、时间、步骤、结果及患者的一般情况,记录操作过", "")
+                .replace("程是否顺利,有无不良反应,术后注意事项,操作医师签名、记录时间等。", "")
+                .replace("手术室完成的、治疗性质的及全麻下完成的有创诊疗操作参照手术管理。(包括介入治疗、胃肠镜", "")
+                .replace("下肿瘤切除/粘膜下肿瘤剥除等)", "");
+        List<String> titles = Lists.newArrayList(
+                "病情记录", "患者手术后情况", "手术简要经过(包括手术方式、术中所见、过程是否顺利、有无并发症等)", "术后去向", "术 后诊断", "术后处理措施", "术后注意 点", "术后应当特别注意观察的事项:", "术后治疗计划(包括术后应当特别注意观察的事项)", "术后中医调护", "医生签名", "医师签名"
+        );
+        titles = CommonAnalysisUtil.sortTitlesNoColon(titles, bqjlText);
+        map.remove("病情记录");
+        CommonAnalysisUtil.cutByTitlesNoColon(bqjlText, titles, 0, map);
+    }
+
+}

+ 101 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiOperationRecordHtmlAnalysis.java

@@ -0,0 +1,101 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Element;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description:
+ * @author: rengb
+ * @time: 2020/9/28 16:36
+ */
+@Slf4j
+public class NingBoZhongYiOperationRecordHtmlAnalysis implements NingBoZhongYiHtmlAnalysis {
+
+    private String modeId = "17";
+
+    @Override
+    public Map<String, String> analysis(String... args) {
+        Map<String, String> map = Maps.newLinkedHashMap();
+        try {
+            String html = args[0];
+            String recTitle = args[1];
+            String recTypeId = args[2];
+            Element bigDivElement = Jsoup.parse(html).selectFirst("body").child(0);
+            analysisGeneral(bigDivElement, map);
+            NingBoZhongYiHtmlAnalysisUtil.mapValueRemoveStartColon(map);
+            //String operatingCrew = null;
+
+            if (!map.containsKey("手术人员") && map.containsKey("手术者") && map.containsKey("助手(一、二)")) {
+                map.put("手术人员", map.get("手术者") + " " + map.get("助手(一、二)"));
+            }
+            if (map.containsKey("术中诊断")) {
+                map.put("手术中诊断", map.get("术中诊断"));
+            }
+            if (map.containsKey("麻醉者")) {
+                map.put("麻醉人员", map.get("麻醉者"));
+            }
+            if (map.containsKey("手术经过(手术一般情况、术中发现;处理、标本处理、病切)")) {
+                map.put("手术经过(包括病人体位,切口处理经过及病理标本肉眼所见)", map.get("手术经过(手术一般情况、术中发现;处理、标本处理、病切)"));
+            }
+            /*if (map.containsKey("手术人员")) {
+                operatingCrew = map.get("手术人员");
+            } else if (map.containsKey("手术者及助手名称")) {
+                operatingCrew = map.get("手术者及助手名称");
+            }
+            if (StringUtil.isNotBlank(operatingCrew)) {
+                CommonAnalysisUtil.cutByTitles(operatingCrew, Lists.newArrayList("主刀", "一助", "二助", "助手", "洗手护士"), 0, map);
+            }
+            if (map.containsKey("主刀")) {
+                map.put("主刀", map.get("主刀").replaceAll("[^\u4E00-\u9FA5]", ""));
+            }*/
+            /*if (map.containsKey("麻醉者")) {
+                String anesthetist = map.get("麻醉者").replace("麻醉医生:", "");
+                map.put("麻醉医师", anesthetist);
+                if (anesthetist.contains("1.")) {
+                    int index = anesthetist.indexOf("1.");
+                    map.put("麻醉医师", anesthetist.substring(0, index));
+                    map.put("手术经过", anesthetist.substring(index));
+                }
+            }*/
+            /*if (map.containsKey("手术日期")) {
+                String operatorDateStr = map.get("手术日期");
+                if (operatorDateStr.contains("--")) {
+                    String[] operatorDate = operatorDateStr.split("--");
+                    map.put("手术开始时间", operatorDate[0]);
+                    map.put("手术结束时间", operatorDate[1]);
+                }
+            }*/
+            CommonAnalysisUtil.makeEmpty(map, "医生签名");
+            NingBoZhongYiHtmlAnalysisUtil.insertModuleId(modeId, recTypeId, map);
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return map;
+    }
+
+    private void analysisGeneral(Element bigDivElement, Map<String, String> map) {
+        /*if (bigDivElement.selectFirst("hr") != null) {
+            bigDivElement.selectFirst("hr").previousElementSiblings().remove();
+        }*/
+        String text = NingBoZhongYiHtmlAnalysisUtil.blockDivToStr(bigDivElement, true);
+        text = text.replaceAll("第1页", "");
+        List<String> titles = Lists.newArrayList(
+                "姓名", "性别", "年龄", "婚姻", "出生日期", "出生年月", "科别", "科室", "病区", "床号", "床位", "住院号",
+                "手术时间", "手术日期", "手术前诊断", "术前诊断", "手术中诊断", "术中诊断", "手术指征", "手术人员", "手 术 者", "助手(一、二)", "麻醉方式", "麻醉人员", "手术经过(包括病人体位,切口处理经过及病理标本肉眼所见)", "手术经过(手术一般情况、术中发现;处理、标本处理、病切)", "麻 醉 者", "洗手护士", "本次手术是否属于非计划再次手术", "接生者",
+                "术前胎心", "手术名称", "术后诊断", "手术者及助手名称", "术中取病理标本", "麻醉方法", "诊断手术/操作简要经过(包括术中有无并发症及具体描述和处理)", "手术经过",
+                "医生签名", "记录时间", "时间", "手术/操作医生", "记录者", "术中输血", "术前宫颈准备日期", "药物名称及用法", "导管或其他", "插入深度",
+                "阴道填塞纱布条", "准备者", "取出日期", "手术方法", "术中特殊情况", "病理检查", "其他", "记录者", "手术者", "医师签字", "日期",
+                "检查子宫位置"
+        );
+        titles = CommonAnalysisUtil.sortTitles(titles, text);
+        CommonAnalysisUtil.cutByTitlesNoColon(text, titles, 0, map);
+    }
+
+}

+ 90 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiPreoperativeHtmlAnalysis.java

@@ -0,0 +1,90 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.lantone.qc.pub.util.StringUtil;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Element;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description:
+ * @author: rengb
+ * @time: 2020/9/17 19:19
+ */
+@Slf4j
+public class NingBoZhongYiPreoperativeHtmlAnalysis implements NingBoZhongYiHtmlAnalysis {
+
+    private String modeId = "11";
+
+    @Override
+    public Map<String, String> analysis(String... args) {
+        Map<String, String> map = Maps.newLinkedHashMap();
+        try {
+            String html = args[0];
+            String recTitle = args[1];
+            String recTypeId = args[2];
+            Element bigDivElement = Jsoup.parse(html).selectFirst("body").child(0);
+            analysisGeneral(bigDivElement, map);
+
+            NingBoZhongYiHtmlAnalysisUtil.mapValueRemoveStartColon(map);
+            NingBoZhongYiHtmlAnalysisUtil.insertModuleId(modeId, recTypeId, map);
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return map;
+    }
+
+    private void analysisGeneral(Element bigDivElement, Map<String, String> map) {
+        /*if (bigDivElement.selectFirst("hr") != null) {
+            bigDivElement.selectFirst("hr").previousElementSiblings().remove();
+        }*/
+        String text = NingBoZhongYiHtmlAnalysisUtil.blockDivToStr(bigDivElement, true).replace("·", "");
+
+        int index1 = text.lastIndexOf("经治医师签名");
+        int index2 = text.lastIndexOf("主刀医师签名");
+        if (index1 != -1 && index2 != -1) {
+            text = text.substring(0, index1)
+                    + text.substring(index1, index2).replace("签字时间", "经治医师签字时间:").replace("年月日时分秒", "")
+                    + text.substring(index2).replace("签字时间", "主刀医师签字时间:").replace("年月日时分秒", "");
+        }
+        text = text.replace("术前讨论及术前小结", "").replace("二、讨论结论:", "").replace("年月日时\n" +
+                "分", "").replace("一、简要病情", "简要病情");
+        List<String> titles = Lists.newArrayList("姓名", "性别", "出生日期", "出生年月", "科别", "科室", "病区", "床号", "床位", "住院号",
+                "讨论时间", "讨论方式", "讨论方式 ", "主持人", "参加人员", "简要病情", "具体讨论意见",
+                "1.术前诊断", "2.手术指征与禁忌征", "3.可替代方案", "4.拟施手术方式(名称)及可能的变更方案", "4.拟施手术方式、名称及可能的变更", "5.计划性多次手术",
+                "5.本次手术是否属于计划性多次手术",
+                "5.拟施麻醉方式", "6.术前特殊准备", "7.主要术中、术后风险及防范措施", "8.术中、术后注意事项(含护理事项)",
+                "6.拟施麻醉方式", "7.术前特殊准备", "8.主要术中、术后风险及防范措施", "9.术中、术后注意事项(含护理事项)",
+                "术前诊断", "手术指征", "拟施手术名称及方式", "拟施麻醉方式", "其他术前相关情况", "注意事项",
+                "经治医师签名", "经治医师签字时间", "主刀医师签名", "医生签名", "主刀医师签字时间");
+        CommonAnalysisUtil.cutByTitles(text, titles, 0, map);
+        CommonAnalysisUtil.processType(map, "5.计划性多次手术");
+        CommonAnalysisUtil.processType(map, "5.本次手术是否属于计划性多次手术");
+        CommonAnalysisUtil.processType(map, "讨论方式");
+        CommonAnalysisUtil.makeEmpty(map, "主刀医生签名");
+        // 解决医生签名显示 年 月 日 时 分
+        signatureTime(map);
+    }
+
+    /**
+     * 解决医生签名时间显示 年 月 日 时 分
+     *
+     * @param map
+     */
+    private void signatureTime(Map<String, String> map) {
+        String goCureDoctor = map.get("经治医生签字时间");
+        String operateDoctor = map.get("主刀医生签字时间");
+        if (StringUtil.isNotBlank(goCureDoctor) && goCureDoctor.contains("年 月 日 时 分")) {
+            map.put("经治医生签字时间", goCureDoctor.replace("年 月 日 时 分", ""));
+        }
+        if (StringUtil.isNotBlank(operateDoctor) && operateDoctor.contains("年 月 日 时 分")) {
+            map.put("主刀医生签字时间", operateDoctor.replace("年 月 日 时 分", ""));
+        }
+    }
+
+}

+ 56 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiRescueHtmlAnalysis.java

@@ -0,0 +1,56 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Element;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description:
+ * @author: rengb
+ * @time: 2020/9/28 20:12
+ */
+@Slf4j
+public class NingBoZhongYiRescueHtmlAnalysis implements NingBoZhongYiHtmlAnalysis {
+
+    private String modeId = "22";
+
+    @Override
+    public Map<String, String> analysis(String... args) {
+        Map<String, String> map = Maps.newLinkedHashMap();
+        try {
+            String html = args[0];
+            String recTitle = args[1];
+            String recTypeId = args[2];
+            Element bigDivElement = Jsoup.parse(html).selectFirst("body").child(0);
+            analysisGeneral(recTitle,bigDivElement, map);
+            NingBoZhongYiHtmlAnalysisUtil.insertModuleId(modeId, recTypeId, map);
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return map;
+    }
+
+    private void analysisGeneral(String recTitle, Element bigDivElement, Map<String, String> map) {
+        if (bigDivElement.childNodeSize() == 1) {
+            bigDivElement = bigDivElement.child(0);
+        }
+        if (bigDivElement.selectFirst("hr") != null) {
+            bigDivElement.selectFirst("hr").previousElementSiblings().remove();
+        }
+        String text = NingBoZhongYiHtmlAnalysisUtil.blockDivToStr(bigDivElement, true);
+        CommonAnalysisUtil.extractWardInfo(recTitle,text, map);
+        String bqjlText = "病情记录" + map.get("病情记录");
+        List<String> titles = Lists.newArrayList(
+                "病情记录"
+        );
+        titles = CommonAnalysisUtil.sortTitlesNoColon(titles, bqjlText);
+        CommonAnalysisUtil.cutByTitlesNoColon(bqjlText, titles, 0, map);
+    }
+
+}

+ 56 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiStagesSummaryHtmlAnalysis.java

@@ -0,0 +1,56 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Element;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description:
+ * @author: rengb
+ * @time: 2020/9/28 20:16
+ */
+@Slf4j
+public class NingBoZhongYiStagesSummaryHtmlAnalysis implements NingBoZhongYiHtmlAnalysis {
+
+    private String modeId = "28";
+
+    @Override
+    public Map<String, String> analysis(String... args) {
+        Map<String, String> map = Maps.newLinkedHashMap();
+        try {
+            String html = args[0];
+            String recTitle = args[1];
+            String recTypeId = args[2];
+            Element bigDivElement = Jsoup.parse(html).selectFirst("body").child(0);
+            analysisGeneral(recTitle, bigDivElement, map);
+            NingBoZhongYiHtmlAnalysisUtil.insertModuleId(modeId, recTypeId, map);
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return map;
+    }
+
+    private void analysisGeneral(String recTitle, Element bigDivElement, Map<String, String> map) {
+        if (bigDivElement.childNodeSize() == 1) {
+            bigDivElement = bigDivElement.child(0);
+        }
+        if (bigDivElement.selectFirst("hr") != null) {
+            bigDivElement.selectFirst("hr").previousElementSiblings().remove();
+        }
+        String text = NingBoZhongYiHtmlAnalysisUtil.blockDivToStr(bigDivElement, true);
+        CommonAnalysisUtil.extractWardInfo(recTitle, text, map);
+        String bqjlText = "病情记录" + map.get("病情记录");
+        List<String> titles = Lists.newArrayList(
+                "病情记录"
+        );
+        titles = CommonAnalysisUtil.sortTitlesNoColon(titles, bqjlText);
+        CommonAnalysisUtil.cutByTitlesNoColon(bqjlText, titles, 0, map);
+    }
+
+}

+ 91 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiThreeLevelWardHtmlAnalysis.java

@@ -0,0 +1,91 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Document;
+import org.jsoup.nodes.Element;
+import org.jsoup.nodes.Node;
+import org.jsoup.select.Elements;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description: 自定义病程记录html解析
+ * @author: HUJING
+ * @time: 2020/9/15 10:28
+ */
+@Slf4j
+public class NingBoZhongYiThreeLevelWardHtmlAnalysis implements NingBoZhongYiHtmlAnalysis {
+
+    private String modeId = "4";
+
+    @Override
+    public Map<String, String> analysis(String... args) {
+        Map<String, String> structureMap = Maps.newLinkedHashMap();
+        try {
+            String html = args[0];
+            String recTitle = args[1];
+            String recTypeId = args[2];
+            Document doc = Jsoup.parse(html);
+            Element bigDivElement = doc.selectFirst("body").child(0);
+            if (bigDivElement.childNodeSize() == 1) {
+                bigDivElement = bigDivElement.child(0);
+            }
+            /*if (bigDivElement.selectFirst("hr") != null) {
+                bigDivElement.selectFirst("hr").previousElementSiblings().remove();
+            }*/
+            String htmlText = NingBoZhongYiHtmlAnalysisUtil.blockDivToStr(bigDivElement, true);
+            /*htmlText = htmlText.replace("注意:上级医师查房主要记 录:患者病情、诊断、鉴别诊断、当前治疗措施和疗效的分析及下一步诊疗意见等,能反应上级医 师的水平。", "")
+                    .replace("提醒:有创诊疗操作记录内容包括操作名称、时间、步骤、结果及患者的一般情况,记录操作过 程是否顺利,有无不良反应,术后注意事项,操作医师签名、记录时间等。 手术室完成的、治疗性质的及全麻下完成的有创诊疗操作参照手术管理。(包括介入治疗、胃肠镜 下肿瘤切除/粘膜下肿瘤剥除等)", "");*/
+            CommonAnalysisUtil.extractWardInfo(recTitle, htmlText, structureMap);
+            NingBoZhongYiHtmlAnalysisUtil.insertModuleId(modeId, recTypeId, structureMap);
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return structureMap;
+    }
+
+    /**
+     * 将html内容以行为单位存进list,从<hr>之后开始处理
+     *
+     * @param html 原始html内容
+     * @return
+     */
+    public static List<String> html2List(String html, boolean existHr) {
+        List<String> htmlText = Lists.newArrayList();
+        Document document = Jsoup.parse(html);
+        Element body = document.select("body").first();
+        List<Node> nodes = body.childNodes();
+        List<Node> subNodes = nodes.get(0).childNodes();
+        boolean findNode = false;
+        for (Node node : subNodes) {
+            if ("hr".equals(node.nodeName())) {
+                findNode = true;
+                continue;
+            }
+            if (findNode || !existHr) {
+                String title = node.attr("title");
+                if ("main".equals(title)) {
+                    Element element = (Element) node;
+                    Elements elements = element.select("div");
+                    for (Element e : elements) {
+                        String text = e.text();
+                        if (text.length() > 150) {
+                            continue;
+                        }
+                        htmlText.add(text);
+                    }
+                }
+            }
+        }
+        if (htmlText.get(0).length() > 200) {
+            htmlText.remove(0);
+        }
+        return htmlText;
+    }
+
+}

+ 56 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiTransferIntoHtmlAnalysis.java

@@ -0,0 +1,56 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Element;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description:
+ * @author: rengb
+ * @time: 2020/9/28 20:20
+ */
+@Slf4j
+public class NingBoZhongYiTransferIntoHtmlAnalysis implements NingBoZhongYiHtmlAnalysis {
+
+    private String modeId = "26";
+
+    @Override
+    public Map<String, String> analysis(String... args) {
+        Map<String, String> map = Maps.newLinkedHashMap();
+        try {
+            String html = args[0];
+            String recTitle = args[1];
+            String recTypeId = args[2];
+            Element bigDivElement = Jsoup.parse(html).selectFirst("body").child(0);
+            analysisGeneral(recTitle, bigDivElement, map);
+            NingBoZhongYiHtmlAnalysisUtil.insertModuleId(modeId, recTypeId, map);
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return map;
+    }
+
+    private void analysisGeneral(String recTitle, Element bigDivElement, Map<String, String> map) {
+        if (bigDivElement.childNodeSize() == 1) {
+            bigDivElement = bigDivElement.child(0);
+        }
+        if (bigDivElement.selectFirst("hr") != null) {
+            bigDivElement.selectFirst("hr").previousElementSiblings().remove();
+        }
+        String text = NingBoZhongYiHtmlAnalysisUtil.blockDivToStr(bigDivElement, true);
+        CommonAnalysisUtil.extractWardInfo(recTitle, text, map);
+        String bqjlText = "病情记录" + map.get("病情记录");
+        List<String> titles = Lists.newArrayList(
+                "病情记录", "医师签名", "医师签字"
+        );
+        titles = CommonAnalysisUtil.sortTitlesNoColon(titles, bqjlText);
+        CommonAnalysisUtil.cutByTitlesNoColon(bqjlText, titles, 0, map);
+    }
+
+}

+ 65 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiTransferOutHtmlAnalysis.java

@@ -0,0 +1,65 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Element;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description:
+ * @author: rengb
+ * @time: 2020/9/28 20:22
+ */
+@Slf4j
+public class NingBoZhongYiTransferOutHtmlAnalysis implements NingBoZhongYiHtmlAnalysis {
+
+    private String modeId = "27";
+
+    @Override
+    public Map<String, String> analysis(String... args) {
+        Map<String, String> map = Maps.newLinkedHashMap();
+        try {
+            String html = args[0];
+            String recTitle = args[1];
+            String recTypeId = args[2];
+            Element bigDivElement = Jsoup.parse(html).selectFirst("body").child(0);
+            analysisGeneral(recTitle, bigDivElement, map);
+            NingBoZhongYiHtmlAnalysisUtil.insertModuleId(modeId, recTypeId, map);
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return map;
+    }
+
+    private void analysisGeneral(String recTitle, Element bigDivElement, Map<String, String> map) {
+        if (bigDivElement.childNodeSize() == 1) {
+            bigDivElement = bigDivElement.child(0);
+        }
+        if (bigDivElement.selectFirst("hr") != null) {
+            bigDivElement.selectFirst("hr").previousElementSiblings().remove();
+        }
+        String text = NingBoZhongYiHtmlAnalysisUtil.blockDivToStr(bigDivElement, true);
+        CommonAnalysisUtil.extractWardInfo(recTitle, text, map);
+        String bqjlText = "病情记录" + map.get("病情记录").replace("年   月   日   时   分 ","");
+        List<String> titles = Lists.newArrayList(
+                "病情记录",
+                "医生签名",
+                "签名时间",
+                "患者签名",
+                "签名时间"
+        );
+        titles = CommonAnalysisUtil.sortTitlesNoColon(titles, bqjlText);
+        CommonAnalysisUtil.cutByTitlesNoColon(bqjlText, titles, 0, map);
+        List<String> tits = Lists.newArrayList(
+                "签名时间",
+                "患者签名"
+        );
+        tits = CommonAnalysisUtil.sortTitlesNoColon(tits, text);
+        CommonAnalysisUtil.cutByTitlesNoColon(text, tits, 0, map);
+    }
+}

+ 41 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/NingBoZhongYiVTEGradeHtmlAnalysis.java

@@ -0,0 +1,41 @@
+package com.lantone.qc.trans.ningbozhongyi.util;
+
+import com.google.common.collect.Maps;
+import lombok.extern.slf4j.Slf4j;
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Document;
+import org.jsoup.nodes.Element;
+
+import java.util.Map;
+
+/**
+ * @ClassName: NingBoZhongYiVTEGradeHtmlAnalysis
+ * @Description: VTE评分HTML解析
+ * @Author songxl
+ * @Date 2021/3/9
+ * @Version 1.0
+ */
+@Slf4j
+public class NingBoZhongYiVTEGradeHtmlAnalysis implements NingBoZhongYiHtmlAnalysis {
+    private String modeId = "0";//模块id待定
+    @Override
+    public Map<String, String> analysis(String... args) {
+        Map<String, String> map = Maps.newLinkedHashMap();
+        try {
+            String html = args[0];
+            String recTitle = args[1];
+            String recTypeId = args[2];
+
+            Document doc = Jsoup.parse(html);
+            //评估日期
+            Element valuationName = doc.getElementById("table4").getElementsByTag("tr").get(2)
+                    .getElementsByTag("span").get(0);
+            Element valuationTime = doc.getElementById("table4").getElementsByTag("tr").get(2)
+                    .getElementsByTag("span").get(1);
+            map.put(valuationName.text().replaceAll(":",""),valuationTime.text());
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+        }
+        return map;
+    }
+}

+ 12 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/ez/EzAnalysis.java

@@ -0,0 +1,12 @@
+package com.lantone.qc.trans.ningbozhongyi.util.ez;
+
+import java.util.Map;
+
+/**
+ * @Description:
+ * @Author: HUJING
+ * @Date: 2021/1/6 14:24
+ */
+public interface EzAnalysis {
+    Map<String, String> analysis(String xml) throws Exception;
+}

+ 41 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/ez/EzClinicalBloodAnalysis.java

@@ -0,0 +1,41 @@
+package com.lantone.qc.trans.ningbozhongyi.util.ez;
+
+import com.google.common.collect.Lists;
+import com.lantone.qc.trans.ningbozhongyi.util.ez.util.EzXmlUtil;
+import lombok.extern.slf4j.Slf4j;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Description: 输血记录解析
+ * @author: HUJING
+ * @time: 2021/1/7 11:20
+ */
+@Slf4j
+public class EzClinicalBloodAnalysis implements EzAnalysis {
+
+    @Override
+    public Map<String, String> analysis(String xml) throws Exception {
+        Map<String, String> map = EzXmlUtil.analysis(xml);
+        Map<String, String> structureMap = EzXmlUtil.mapKeyContrast(map, keyContrasts);
+        return map;
+    }
+
+    /**
+     * 目前能解析字段:
+     * 全文本
+     * 诊断
+     * 检验结果
+     * 血型
+     * 输注量
+     * 输血开始时间
+     * 输血日期end
+     * 输血结束时间
+     * 输血指征
+     */
+    private static List<String> keyContrasts = Lists.newArrayList(
+            "输注量=输血量(mL)",
+            "血型=ABO血型代码"
+    );
+}

+ 21 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/ez/EzDeathCaseDiscussAnalysis.java

@@ -0,0 +1,21 @@
+package com.lantone.qc.trans.ningbozhongyi.util.ez;
+
+import com.lantone.qc.trans.ningbozhongyi.util.ez.util.EzXmlUtil;
+import lombok.extern.slf4j.Slf4j;
+
+import java.util.Map;
+
+/**
+ * @Description: 死亡病例讨论记录文档生成
+ * @author: HUJING
+ * @time: 2021/1/4 17:25
+ */
+@Slf4j
+public class EzDeathCaseDiscussAnalysis implements EzAnalysis {
+
+    @Override
+    public Map<String, String> analysis(String xml) throws Exception {
+        Map<String, String> map = EzXmlUtil.analysis(xml);
+        return map;
+    }
+}

+ 40 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/ez/EzOperationRecordAnalysis.java

@@ -0,0 +1,40 @@
+package com.lantone.qc.trans.ningbozhongyi.util.ez;
+
+import com.lantone.qc.trans.ningbozhongyi.util.ez.util.EzXmlUtil;
+import lombok.extern.slf4j.Slf4j;
+
+import java.util.Map;
+
+/**
+ * @Description: 手术记录解析
+ * @author: HUJING
+ * @time: 2021/1/7 11:20
+ */
+@Slf4j
+public class EzOperationRecordAnalysis implements EzAnalysis {
+
+    @Override
+    public Map<String, String> analysis(String xml) throws Exception {
+        Map<String, String> map = EzXmlUtil.analysis(xml);
+        if (map.containsKey("手术结束时间")) {
+            map.put("手术结束时间", map.get("手术结束时间").split(" ")[0]);
+        }
+        return map;
+    }
+    /**
+     * 目前能解析字段:
+     *  手术开始时间
+     *  手术结束时间
+     *  术前诊断
+     *  手术名称
+     *  术中诊断
+     *  手 术 者
+     *  麻醉方法
+     *  麻 醉 者
+     *  术中并发症
+     *  存在问题
+     *  术中失血量
+     *  手术经过
+     *  日期
+     */
+}

+ 337 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/ez/EzXmlAnalysis.java

@@ -0,0 +1,337 @@
+package com.lantone.qc.trans.ningbozhongyi.util.ez;
+
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.lantone.qc.pub.util.StringUtil;
+import com.lantone.qc.trans.comsis.CommonAnalysisUtil;
+import org.dom4j.Document;
+import org.dom4j.DocumentHelper;
+import org.dom4j.Element;
+import org.dom4j.Node;
+
+import java.util.List;
+import java.util.Map;
+import java.util.regex.Matcher;
+import java.util.regex.Pattern;
+
+/**
+ * @Description:
+ * @author: rengb
+ * @time: 2020/9/24 11:28
+ */
+public class EzXmlAnalysis {
+
+    public static Map<String, String> analysis(String deptName, String xml) throws Exception {
+        if (deptName.equals("小儿外科")) {
+            return analysisEk(deptName, xml);
+        }
+        return null;
+    }
+
+    public static Map<String, String> analysisEk(String deptName, String xml) throws Exception {
+        Map<String, String> map = Maps.newLinkedHashMap();
+        Document doc = DocumentHelper.parseText(xml);
+        Element rootElement = doc.getRootElement();
+        jbxxInsertMap(rootElement, map);
+        tgjcInsertMap(rootElement, map);
+        fzjcInsertMap(rootElement, map);
+        zkjcInsertMap(rootElement, map);
+        disInsertMap(rootElement, map);
+        otherInsertMap(rootElement, map);
+        return map;
+    }
+
+    //其他信息
+    public static void otherInsertMap(Element rootElement, Map<String, String> map) {
+        List<String> titles = Lists.newArrayList(
+                "主诉", "现病史", "既往史", "手术史", "输血史", "过敏史", "个人史", "预防接种史", "家族史", "婚育史", "月经史"
+        );
+        String rootText = elementTxt(rootElement);
+        String signTimeStr = findTimeStr(rootText.substring(rootText.length() - 18));
+        if (StringUtil.isNotBlank(signTimeStr)) {
+            rootText = rootText.substring(0, rootText.lastIndexOf(signTimeStr));
+        }
+        titles = CommonAnalysisUtil.sortTitlesNoColon(titles, rootText);
+        CommonAnalysisUtil.cutByTitlesNoColon(rootText, titles, 0, map);
+    }
+
+    public static void disInsertMap(Element rootElement, Map<String, String> map) {
+        Node cbzdNode = rootElement.selectSingleNode("section[@name='初步诊断']");
+        if (cbzdNode != null) {
+            rootElement.remove(cbzdNode);
+        }
+        Node disNode = rootElement.selectSingleNode("section[@name='诊断']");
+        if (disNode != null) {
+            String disText = elementTxt(disNode);
+            List<String> titles = CommonAnalysisUtil.sortTitlesNoColon(Lists.newArrayList("初步诊断", "补充诊断", "再次补充诊断", "修正诊断", "出院诊断"), disText);
+            CommonAnalysisUtil.cutByTitlesNoColon(disText, titles, 0, map);
+            titles.forEach(title -> {
+                disExt(map, title);
+            });
+            rootElement.remove(disNode);
+        }
+    }
+
+    //诊断特殊处理
+    public static void disExt(Map<String, String> map, String key) {
+        String disMessage = map.get(key);
+        String sign = null;
+        String signTime = null;
+        int signIndex = 0;
+        if (StringUtil.isNotBlank(disMessage)) {
+            Pattern pattern = Pattern.compile("[0-9]+[年/-][0-9]+[月/-][0-9]+[日]{0,}");
+            Matcher matcher = pattern.matcher(disMessage);
+            if (matcher.find()) {
+                signTime = matcher.group();
+                disMessage = disMessage.substring(0, matcher.start());
+            }
+
+            signIndex = disMessage.indexOf("医师签名");
+            if (signIndex > -1) {
+                sign = disMessage.substring(signIndex).replace("医师签名", "").replaceAll("[::]", "");
+                disMessage = disMessage.substring(0, signIndex);
+            }
+            map.put(key, disMessage);
+            if (StringUtil.isNotBlank(sign)) {
+                map.put(key + "签名", sign.replaceAll("日期", ""));
+            }
+            if (StringUtil.isNotBlank(signTime)) {
+                map.put(key + "签名日期", signTime);
+            }
+        }
+    }
+
+    //辅助检查
+    public static void fzjcInsertMap(Element rootElement, Map<String, String> map) {
+        Node fzjcNode = rootElement.selectSingleNode("section[@name='辅助检查']");
+        if (fzjcNode != null) {
+            map.put("辅助检查", elementTxt(fzjcNode).replaceFirst("辅助检查", ""));
+            rootElement.remove(fzjcNode);
+        }
+    }
+
+    // 专科检查
+    public static void zkjcInsertMap(Element rootElement, Map<String, String> map) {
+        Node zkjcNode = rootElement.selectSingleNode("section[@name='专科检查']");
+        if (zkjcNode != null) {
+            map.put("专科检查", elementTxt(zkjcNode).replaceFirst("专科检查", ""));
+            rootElement.remove(zkjcNode);
+        }
+    }
+
+    //基本信息
+    public static void jbxxInsertMap(Element rootElement, Map<String, String> map) {
+        Node jbxxNode = rootElement.selectSingleNode("section[@name='基本信息']");
+        if (jbxxNode != null) {
+            ((List<Element>) jbxxNode.selectNodes("fieldelem")).forEach(i -> {
+                elementInsertMap(i, map);
+            });
+            String age = map.get("年龄");
+            String ageYear = "";
+            String ageMon = "";
+            if (StringUtil.isNotBlank(age)) {
+                ageYear = age;
+                if (age.indexOf("岁") > -1) {
+                    ageYear = age;
+                } else if (age.indexOf("月") > -1) {
+                    ageYear = "";
+                    ageMon = age;
+                }
+            }
+            map.put("年龄岁", ageYear);
+            map.put("年龄月", ageMon);
+            rootElement.remove(jbxxNode);
+        }
+    }
+
+    //身高体重
+    public static void sgtzInsertMap(Element rootElement, Map<String, String> map) {
+        Map<String, String> map2 = Maps.newHashMap();
+        Node tgjcNode = rootElement.selectSingleNode("section[@name='体格检查']");
+        if (tgjcNode != null) {
+            Node ybqkNode = tgjcNode.selectSingleNode("section[@name='一般情况']");
+            if (ybqkNode != null) {
+                if (StringUtil.isBlank(map.get("身高"))) {
+                    elementInsertMap((Element) ybqkNode.selectSingleNode("fieldelem[@name='身高']"), map);
+                }
+                if (StringUtil.isBlank(map.get("体重"))) {
+                    elementInsertMap((Element) ybqkNode.selectSingleNode("fieldelem[@name='体重']"), map);
+                }
+
+                String ybqkText = elementTxt(ybqkNode);
+                List<String> titles = Lists.newArrayList("身高", "体重");
+                titles = CommonAnalysisUtil.sortTitlesNoColon(titles, ybqkText);
+                CommonAnalysisUtil.cutByTitlesNoColon(ybqkText, titles, 0, map2);
+                sgtzxyInsertMap(map2);
+            }
+        }
+
+        smtzSgtzInsertMap(rootElement, map2);
+        if (!map.containsKey("身高")) {
+            map.put("身高", map2.get("身高"));
+
+        }
+        if (!map.containsKey("体重")) {
+            map.put("体重", map2.get("体重"));
+        }
+        if (!map.containsKey("收缩压")) {
+            map.put("收缩压", map2.get("收缩压"));
+        }
+        if (!map.containsKey("舒张压")) {
+            map.put("舒张压", map2.get("舒张压"));
+        }
+    }
+
+    //生命体征中提取身高体重
+    public static void smtzSgtzInsertMap(Element rootElement, Map<String, String> map) {
+        Node tgjcNode = rootElement.selectSingleNode("section[@name='体格检查']");
+        if (tgjcNode != null) {
+            Node smtzNode = tgjcNode.selectSingleNode("section[@name='生命体征']");
+            if (smtzNode != null) {
+                Map<String, String> map2 = Maps.newHashMap();
+                String smtzText = elementTxt(smtzNode);
+                List<String> titles = Lists.newArrayList("身高", "体重", "血压", "BP");
+                titles = CommonAnalysisUtil.sortTitlesNoColon(titles, smtzText);
+                CommonAnalysisUtil.cutByTitlesNoColon(smtzText, titles, 0, map2);
+                sgtzxyInsertMap(map2);
+
+                map.put("收缩压", map2.get("收缩压"));
+                map.put("舒张压", map2.get("舒张压"));
+                if (StringUtil.isBlank(map.get("身高"))) {
+                    map.put("身高", map2.get("身高"));
+                }
+                if (StringUtil.isBlank(map.get("体重"))) {
+                    map.put("体重", map2.get("体重"));
+                }
+            }
+        }
+    }
+
+    //身高、体重、血压公共处理方法
+    private static void sgtzxyInsertMap(Map<String, String> map) {
+        Pattern pattern = Pattern.compile("[0-9]+[.]{0,1}[0-9]*");
+        if (map.containsKey("身高")) {
+            String value = map.get("身高");
+            if (StringUtil.isNotBlank(value)) {
+                value = StringUtil.removeBlank(value);
+                Matcher matcher = pattern.matcher(value);
+                if (matcher.find()) {
+                    map.put("身高", matcher.group());
+                } else {
+                    map.put("身高", "");
+                }
+            }
+        }
+        if (map.containsKey("体重")) {
+            String value = map.get("体重");
+            if (StringUtil.isNotBlank(value)) {
+                value = StringUtil.removeBlank(value);
+                Matcher matcher = pattern.matcher(value);
+                if (matcher.find()) {
+                    map.put("体重", matcher.group());
+                } else {
+                    map.put("体重", "");
+                }
+            }
+        }
+        pattern = Pattern.compile("[0-9]+[.]{0,1}[0-9]*/[0-9]+[.]{0,1}[0-9]*");
+        if (map.containsKey("血压") || map.containsKey("BP")) {
+            String value = map.get("血压");
+            if (StringUtil.isBlank(value)) {
+                value = map.get("BP");
+            }
+            if (StringUtil.isNotBlank(value)) {
+                value = StringUtil.removeBlank(value);
+                Matcher matcher = pattern.matcher(value);
+                if (matcher.find()) {
+                    value = matcher.group();
+                    String[] arry = value.split("/");
+                    if (arry.length == 2) {
+                        map.put("收缩压", arry[0]);
+                        map.put("舒张压", arry[1]);
+                    }
+                }
+            }
+        }
+    }
+
+    //体格检查
+    public static void tgjcInsertMap(Element rootElement, Map<String, String> map) {
+        Node tgjcNode = rootElement.selectSingleNode("section[@name='体格检查']");
+        if (tgjcNode != null) {
+            Node smtzNode = tgjcNode.selectSingleNode("section[@name='生命体征']");
+            if (smtzNode != null) {
+                ((List<Element>) smtzNode.selectNodes("fieldelem")).forEach(i -> {
+                    elementInsertMap(i, map);
+                });
+            }
+            ((List<Element>) tgjcNode.selectNodes("section[@name!='生命体征']")).forEach(i -> {
+                elementInsertMap(i, map);
+            });
+
+            String jzsz = map.get("脊柱四肢");
+            String jz = "";
+            String sz = "";
+            if (StringUtil.isNotBlank(jzsz)) {
+                if (jzsz.indexOf("四肢") > -1) {
+                    jz = jzsz.substring(0, jzsz.indexOf("四肢"));
+                    sz = jzsz.substring(jzsz.indexOf("四肢"));
+                } else {
+                    jz = jzsz;
+                }
+            }
+            map.put("脊柱", jz);
+            map.put("四肢", sz);
+            sgtzInsertMap(rootElement, map);
+            rootElement.remove(tgjcNode);
+        }
+    }
+
+    public static String elementTxt(Node node) {
+        if (node != null) {
+            return StringUtil.removeBlank(node.getStringValue());
+        } else {
+            return "";
+        }
+    }
+
+    public static void elementInsertMap(Element element, Map<String, String> map) {
+        if (element == null || map == null) {
+            return;
+        }
+        String key = null;
+        List<Element> elements = element.elements();
+        if (elements.size() > 0 && (key = isKey(elementTxt(elements.get(0)))) != null) {
+            element.remove(elements.get(0));
+        } else {
+            key = element.attributeValue("name");
+        }
+        if (StringUtil.isNotBlank(key)) {
+            map.put(key, elementTxt(element));
+        }
+    }
+
+    public static String isKey(String key) {
+        if (StringUtil.isBlank(key)) {
+            return null;
+        }
+        key = StringUtil.removeBlank(key);
+        Pattern pattern = Pattern.compile("[\\u4e00-\\u9fa5]+[::]");
+        if (pattern.matcher(key).matches()) {
+            return key.substring(0, key.length() - 1);
+        } else {
+            return null;
+        }
+    }
+
+    public static String findTimeStr(String text) {
+        String ret = "";
+        Pattern pattern = Pattern.compile("[0-9]+[年/-][0-9]+[月/-][0-9]+[日]{0,}");
+        Matcher matcher = pattern.matcher(text);
+        if (matcher.find()) {
+            ret = matcher.group();
+        }
+        return ret;
+    }
+
+}

+ 143 - 0
trans/src/main/java/com/lantone/qc/trans/ningbozhongyi/util/ez/util/EzXmlUtil.java

@@ -0,0 +1,143 @@
+package com.lantone.qc.trans.ningbozhongyi.util.ez.util;
+
+import com.google.common.collect.Maps;
+import com.lantone.qc.dbanaly.facade.yiwu.util.MapUtil;
+import com.lantone.qc.pub.util.StringUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.dom4j.*;
+
+import java.util.HashSet;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+
+/**
+ * @Description:
+ * @author: HUJING
+ * @time: 2021/1/4 14:30
+ */
+@Slf4j
+public class EzXmlUtil {
+
+    public static Map<String, String> analysis(String xml) throws Exception {
+        Map<String, String> map = Maps.newLinkedHashMap();
+        try {
+            Document doc = DocumentHelper.parseText(bom(xml));
+            Element rootElement = doc.getRootElement();
+            findAllNodes(rootElement, map);
+        } catch (Exception e) {
+            log.error(e.getMessage(), e);
+            throw new Exception("xml解析错误:" + e.getMessage());
+        }
+        return map;
+    }
+
+    /**
+     * 从指定节点开始,向下寻找所有节点 ,包括其子节点<br/>
+     *
+     * @param node 所指定的节点
+     */
+    public static void findAllNodes(Element node, Map<String, String> map) {
+
+        putNode(node, map);
+
+        // 递归遍历当前节点所有的子节点
+        List<Element> listElement = node.elements();
+
+        // 遍历所有一级子节点
+        for (Element e : listElement) {
+            findAllNodes(e, map);// 递归
+        }
+    }
+
+    /**
+     * 存放节点,不包括其子节点
+     *
+     * @param node 所指定的节点
+     */
+    public static void putNode(Element node, Map<String, String> map) {
+        String labelName = node.getName();
+        List<Attribute> listAttr = node.attributes();// 所有属性
+        for (Attribute attr : listAttr) {// 遍历所有属性
+            //String name = attr.getName();// 属性名称
+            if (("fieldelem".equals(labelName)) && StringUtil.isNotBlank(attr.getValue())) {
+                String fieldelemKey = attr.getValue();// 属性的值
+                String text = node.getStringValue();
+                map.put(fieldelemKey, text);
+            }
+            if ("section".equals(labelName)) {
+                List<Element> content = node.content();
+                if (content.size() > 0) {
+                    Element firstEle = content.get(0);
+                    String key = firstEle.getStringValue();
+                    if (key.endsWith(":")) {
+                        key = key.substring(0, key.length() - 1);
+                    }
+                    String value = "";
+                    for (int i = 1; i < content.size(); i++) {
+                        String v = content.get(i).getStringValue();
+                        value += v + " ";
+                    }
+                    map.put(key, value);
+                }
+            }
+        }
+    }
+
+    public static String bom(String result) {
+        if (null != result && !"".equals(result)) {
+            if (result.contains("<") && result.lastIndexOf(">") != -1 && result.lastIndexOf(">") > result.indexOf("<")) {
+                result = result.substring(result.indexOf("<"), result.lastIndexOf(">") + 1);
+            }
+        }
+        return result;
+    }
+
+    public static String elementTxt(Node node) {
+        if (node != null) {
+            return StringUtil.removeBlank(node.getStringValue());
+        } else {
+            return "";
+        }
+    }
+
+    /**
+     * 根据给定key映射
+     *
+     * @param sourceMap
+     * @param keyContrasts
+     * @return
+     */
+    public static Map<String, String> mapKeyContrast(Map<String, String> sourceMap, List<String> keyContrasts) {
+        Map<String, String> retMap = Maps.newHashMap();
+        mapKeyContrastCommon(sourceMap, keyContrasts, retMap);
+        return retMap;
+    }
+
+    public static void mapKeyContrastCommon(Map sourceMap, List<String> keyContrasts, Map<String, String> retMap) {
+        Map<String, String> sourceMap_ = MapUtil.copyMap(sourceMap);
+        String[] arry = null;
+        String sourceKey = null, targetKey;
+        Set<String> removeKey = new HashSet<>();
+        for (String keyContrast : keyContrasts) {
+            arry = keyContrast.split("=");
+            sourceKey = arry[0];
+            if (arry.length == 1) {
+                targetKey = arry[0];
+            } else {
+                targetKey = arry[1];
+            }
+            if (StringUtil.isNotBlank(sourceMap_.get(sourceKey))
+                    && (!retMap.containsKey(targetKey) || StringUtil.isBlank(retMap.get(targetKey)))) {
+                retMap.put(targetKey, sourceMap_.get(sourceKey));
+            }
+            removeKey.add(sourceKey);
+        }
+        Set<String> keySet = retMap.keySet();
+        for (String key : sourceMap_.keySet()) {
+            if (!keySet.contains(key) && !removeKey.contains(key)) { // 如果之前已放过key就不用放了
+                retMap.put(key, sourceMap_.get(key));
+            }
+        }
+    }
+}