update ICF importer to handle grouping levels

This commit is contained in:
Grahame Grieve 2023-07-29 08:48:09 +10:00
parent 0165495626
commit 8a893ee793
1 changed files with 47 additions and 22 deletions

View File

@ -42,35 +42,60 @@ public class ICFImporter {
cs.setCopyright("© World Health Organization 2022\r\nSome rights reserved. This work is available under the Creative Commons Attribution-NoDerivatives 3.0 IGO license (CC BY-ND 3.0 IGO further specified at [[https://icd.who.int/en/docs/ICD11-license.pdf]]). \r\nUnder the terms of this license, you may copy and redistribute the work, provided the work is appropriately cited, as indicated below. In any use of this work, there should be no suggestion that WHO endorses any specific organization, products or services. The use of the WHO logo is not permitted. This license does not allow you to produce adaptations of the work (including translations) without permission from WHO.\r\nAny mediation relating to disputes arising under the license shall be conducted in accordance with the mediation rules of the World Intellectual Property Organization.\r\nThis FHIR version of ICD-11 was generated to support the FHIR Community. The definitive version of ICD-11 is available from [[https://icd.who.int/browse11/l-m/en]].\r\n"); cs.setCopyright("© World Health Organization 2022\r\nSome rights reserved. This work is available under the Creative Commons Attribution-NoDerivatives 3.0 IGO license (CC BY-ND 3.0 IGO further specified at [[https://icd.who.int/en/docs/ICD11-license.pdf]]). \r\nUnder the terms of this license, you may copy and redistribute the work, provided the work is appropriately cited, as indicated below. In any use of this work, there should be no suggestion that WHO endorses any specific organization, products or services. The use of the WHO logo is not permitted. This license does not allow you to produce adaptations of the work (including translations) without permission from WHO.\r\nAny mediation relating to disputes arising under the license shall be conducted in accordance with the mediation rules of the World Intellectual Property Organization.\r\nThis FHIR version of ICD-11 was generated to support the FHIR Community. The definitive version of ICD-11 is available from [[https://icd.who.int/browse11/l-m/en]].\r\n");
cs.addProperty().setCode("icd11-uri").setDescription("Entity URI to map to ICD_11").setType(PropertyType.CODE); cs.addProperty().setCode("icd11-uri").setDescription("Entity URI to map to ICD_11").setType(PropertyType.CODE);
cs.addProperty().setCode("kind").setDescription("Whether concept is chapter, block, or category").setType(PropertyType.CODE);
cs.addProperty().setCode("IsResidual").setDescription("True if the concept is not completely defined by ICD-11").setType(PropertyType.BOOLEAN); cs.addProperty().setCode("IsResidual").setDescription("True if the concept is not completely defined by ICD-11").setType(PropertyType.BOOLEAN);
Map<Integer, ConceptDefinitionComponent> codes = new HashMap<>(); Map<String, ConceptDefinitionComponent> codes = new HashMap<>();
int lastChapter = 0;
int lastBlock = 0;
while (csv.line()) { while (csv.line()) {
String kind = csv.cell("ClassKind");
String code = csv.cell("Code"); String code = csv.cell("Code");
if (!Utilities.noString(code)) { if (Utilities.noString(code)) {
ConceptDefinitionComponent c = new ConceptDefinitionComponent(); code = csv.cell("BlockId");
c.setCode(code); }
c.setDisplay(fixDisplay(csv.cell("Title"))); ConceptDefinitionComponent c = new ConceptDefinitionComponent();
c.addProperty().setCode("uri").setValue(new CodeType(csv.cell("Linearization (release) URI"))); c.setCode(code);
String b = csv.cell("IsResidual").toLowerCase(); c.setDisplay(fixDisplay(csv.cell("Title")));
if (!"false".equals(b)) { c.addProperty().setCode("uri").setValue(new CodeType(csv.cell("Linearization (release) URI")));
c.addProperty().setCode("IsResidual").setValue(new BooleanType(b)); c.addProperty().setCode("kind").setValue(new CodeType(kind));
String b = csv.cell("IsResidual").toLowerCase();
if (!"false".equals(b)) {
c.addProperty().setCode("IsResidual").setValue(new BooleanType(b));
}
int level = Integer.parseInt(csv.cell("DepthInKind"));
String id = kind+"-"+level;
String parentId = null;
switch (kind) {
case "chapter":
parentId = null;
lastChapter = level;
break;
case "block":
parentId = "chapter-"+lastChapter;
lastBlock = level;
break;
case "category":
parentId = "block-"+lastBlock;
break;
} }
Integer level = Integer.parseInt(csv.cell("DepthInKind")); if (level > 1) {
if (level == 1) { parentId = kind+"-"+(level - 1);
cs.getConcept().add(c); }
} else { System.out.println(code+" "+kind+" "+level+" "+id+" "+parentId+" ("+lastChapter+" "+lastBlock+")");
ConceptDefinitionComponent p = codes.get(level -1); if (parentId == null) {
p.getConcept().add(c); cs.getConcept().add(c);
} } else {
codes.put(level, c); ConceptDefinitionComponent p = codes.get(parentId);
for (int i = level + 1; i < 100; i++) { p.getConcept().add(c);
if (codes.containsKey(i)) { }
codes.remove(i); codes.put(id, c);
} for (int i = level + 1; i < 100; i++) {
if (codes.containsKey(i)) {
codes.remove(i);
} }
} }
} }
csv.close(); csv.close();
new JsonParser().setOutputStyle(OutputStyle.PRETTY).compose(new FileOutputStream(dst), cs); new JsonParser().setOutputStyle(OutputStyle.PRETTY).compose(new FileOutputStream(dst), cs);