どうすれば|ADT^A05|
抜け出せますか
"MSH|^~\&|PHTADT09|ABC|DADIST00|ABC|20120425152829|rcalini1|ADT^A05|20429208851634|P|2.1|560"
私はこれを試しましたが、動作しません
"|([A-Z]{3})^([A-Z]{1})([0-9]{2})|"
次のような区切り文字がある場合、正規表現は必要ないと思います|
var adt = text.Split('|')[8];
HL7形式の定義を参照してください
メッセージ内の各セグメントはコンポジットまたはフィールドに分割され、フィールドはパイプ文字 ('|') で区切られます。
|
and^
は正規表現の特殊文字であるため、エスケープする必要があります。
@"\|([A-Z]{3})\^([A-Z]{1})([0-9]{2})\|"
または、逐語的なリテラルが気に入らない場合は、次のようにします。
"\\|([A-Z]{3})\\^([A-Z]{1})([0-9]{2})\\|"
逐語的なリテラル (@
開始引用符の前に使用) により、正規表現が大幅に読みやすくなります (そして移植性が向上します。その正規表現をコピーして別の場所に貼り付けることができます)。よほどの理由がない限り、正規表現文字列には常にそのままのリテラルを使用する必要があります。
特定の文字の前にバックスラッシュを置きます:|
および^
.
\|([A-Z]{3})\^([A-Z]{1})([0-9]{2})\|
編集:私のお気に入りのサイト - http://regexpal.com/
BizTalk にアクセスできる場合、Microsoft は、メッセージを XML に分割するHL7 のアクセラレータを提供しています。それ以外の場合は、LBの答えを使用して、文字列を直接分割します。