提取模式之間的單字

提取模式之間的單字

我有一個文件,我需要從中提取兩個模式之間的單字

例如我需要在之間提取originatingMessageId

對於這個輸入檔案

userGLN|originatingMessageId0028400000000~20170412194316~1182055~1/originatingMessageId/header|documentException|originatingDocumentId|0028400000000~20170412194316~1182055~1~15~19649/originatingDocumentId|link|operation|DELETE|operation||informationProviderGLN|0028400000000|informationProviderGLN|

預期的輸出文件將是:

0028400000000~20170412194316~1182055~1

答案1

str='originatingMessageId'

awk -F"/?$str" '$0=$2'

grep -oP "\|${str}\\K.*?(?=/${str})"

sed -e "s|/\{0,1\}$str|\n|;s/.*\n//;s|/\{0,1\}$str|\n|;/\n/P;d"

相關內容