我有一个 HL7 文件,例如:
MSH|^~\&|ABC|000|ABC|ABC|0000||ABC|000|A|00
PID|1|000|||ABC||000|A||||||||||
OBR|1|||00||00|00|||||||||||ABC|00|0|0||||A|||||00||ABC|7ABC||ABC
OBX|1|ABC|ABC|1|SGVsbG8=
OBX|2|ABC|ABC|1|XYTA
OBX|3|ABC|ABC|1|UYYA
我必须只阅读 OBX 段并在第 5 个管道 (|) 之后获取文本。
目前我正在这样做:
StreamReader reader = new StreamReader(@"C:\Users\vemarajs\Desktop\HL7\Ministry\HSHS.txt");
string strTest = reader.ReadToEnd();
string OBX1 = strTest.Split('\n')[3];
File.AppendAllText(@"C:\Users\vemarajs\Desktop\Test\OBX.txt", OBX1 + Environment.NewLine);
List<string> list = new List<string>();
using (reader)
{
string line;
while ((line = reader.ReadLine()) != null)
{
list.Add(line);
if (line.StartsWith("OBX|") == true)
{
string txt = line.Split('|')[5];
File.AppendAllText(@"C:\Users\vemarajs\Desktop\Test\test.txt", txt+Environment.NewLine);
}
else
{
//string x = line + Environment.NewLine + OBX1.Distinct();
File.AppendAllText(@"C:\Users\vemarajs\Desktop\Test\newtest.txt", line + Environment.NewLine);
}
File.AppendAllText(@"C:\Users\vemarajs\Desktop\Test\newtest.txt", OBX1.Distinct().ToList() + Environment.NewLine);
这会在元素 5 处提取每个 OBX 段的内容(在 5 个管道之后)并写出一个名为 test.text 的文件,在我的 else 语句中,我试图通过删除 OBX|2 和 OBX|3 来修改原始 HL7 文件只有一个 OBX|1,因为我们希望 HL7 文件中的 OBX 段数达到 40 或更多,并且我们不希望在将消息返回到其消息框时保留这些段数。
如何在不说行号为 4 的情况下获得 OBX|1 的第一次出现,这可能会改变。
这是工作代码:
StreamReader reader = new StreamReader(@"C:\Users\vemarajs\Desktop\HL7\Ministry\HSHS.txt");
string strTest = reader.ReadToEnd();
reader.DiscardBufferedData();
reader.BaseStream.Seek(0, SeekOrigin.Begin);
reader.BaseStream.Position = 0;
string OBXstr = string.Empty;
string x = null;
string fileName = Guid.NewGuid().ToString() + ".txt";
StringBuilder sb = new StringBuilder();
List<string> list = new List<string>();
using (reader)
{
string line;
while ((line = reader.ReadLine()) != null)
{
list.Add(line);
if (line.StartsWith("OBX|") == true)
{
string txt = line.Split('|')[5];
File.AppendAllText(@"C:\Users\vemarajs\Desktop\Test\"+fileName, txt + Environment.NewLine);
}
else
{
sb.AppendLine(line);
}
}
int obx1Index = 0;
int obx2Index = 0;
var obx1IDR = "\r" + "OBX" + "|" + "1";
var obx1IDN = "\n" + "OBX" + "|" + "1";
var obx2IDR = "\r" + "OBX" + "|" + "2";
var obx2IDN = "\n" + "OBX" + "|" + "2";
obx1Index = strTest.IndexOf(obx1IDN);
if (obx1Index < 1)
obx1Index = strTest.IndexOf(obx1IDR);
obx2Index = strTest.IndexOf(obx2IDN);
if (obx2Index < 1)
obx2Index = strTest.IndexOf(obx2IDR);
if (obx1Index > 0)
{
OBXstr = strTest.Substring(obx1Index, obx2Index - obx1Index - 1);
OBXstr = OBXstr.Replace(strTest.Substring(obx1Index, obx2Index - obx1Index - 1).Split('|')[5], fileName);
}
}
sb.Append(OBXstr);
x = sb.ToString();
File.WriteAllText(@"C:\Users\vemarajs\Desktop\Test\newtest.txt", x);
reader.Close();