わかりました、1 週間前に投稿した別の質問をフォローしています。 ^ 文字を解析できません
私の現在の状況は、必要な正規表現を解析して後続の要素を作成できるようになったことです。要素タイプごとにタグを作成しました。
たとえば、入力文字列は A|1|2|3^4|B||1|2|3^4^5 です
したがって、この文字列のタグは A と B です
私の出力は(期待される)
A1 1
A2 2
A3.1 3
A3.2 4
B1 (BLANK) //not B
B2 1
B3 2
B4.1 3
B4.2 4
B4.3 5
入力は B||1|2 であるため、理由 B1 は空白にする必要があります。私の現在の出力は
element1 A
element2 1
element3.1 2
element3.2 3
element4 4
element5 B
element6
element7.1 2
element7.2 3
element7.3 4
element7.4 5
基本的に、HL7 パーサーを構築しようとしています。混乱を避け、機密性を維持するために、正確なタグへの置換が行われます。コードは以下の通りです。
パブリック クラス パーサー {
public static final String ELEMENT_DELIM_REGEX = "\\|"; public static void main(String[] args) { String input = "A|1|2|3^4|"; String[] tokens = input.split(ELEMENT_DELIM_REGEX); Element[] elements = new Element[tokens.length]; for (int i = 0; i < tokens.length; i++) { elements[i] = new Element(i + 1, tokens[i]); } for (Element element : elements) { System.out.println(element); } }
}
と
Element.java
パブリッククラス要素{
public static final String SUB_ELEMENT_DELIM_REGEX = "\\^"; private int number; private String[] content; public Element(int number, String content) { this.number = number; this.content = content.split(SUB_ELEMENT_DELIM_REGEX); } @Override public String toString() { if (content.length == 1) { return "Element " + number + "\t" + content[0]; } StringBuilder str = new StringBuilder(); for (int i = 0; i < content.length; i++) { str.append("Element " + number + "." + (i+1) + "\t" + content[i] + "\n"); } // Delete the last \n str.replace(str.length() - 1, str.length(), ""); return str.toString(); } }