我知道还有更优雅的变体,但这些变体应该简单易懂。
试试你的变量不要混淆
Assignfile ( filehan, 'EMP.txt');
Reset ( filehand );
CloseFile (FFile);
一个filehan
和另一个filehand
和FFile
一个 TStringList 的特殊特性,你的 SubStrings 函数只需要一行代码。
sList.text:=StringReplace(AString,ADelimiter,#13#10,[rfReplaceAll]);
- 只有4个变量。
- 只有 1 个 TStringList 。
用德尔福 5 测试
var
LineOfText : String;
sList : TStringList;
filehand,Outfilehand: text;
function SubStrings(AString: String; ADelimiter: Char; var sList: TStringList):Boolean;
begin
sList.text:=StringReplace(AString,ADelimiter,#13#10,[rfReplaceAll]);
end;
begin
sList := TStringList.Create;
Assignfile ( filehand, 'EMP.txt');
Assignfile ( Outfilehand, 'FSTRING.txt');
Reset ( filehand );
Rewrite(Outfilehand);
try
While not EOF(filehand) do
begin
ReadLn ( filehand, LineOfText );
LineOfText:=StringReplace(LineOfText,': ',':',[rfReplaceAll]);
LineOfText:=StringReplace(LineOfText,' :',':',[rfReplaceAll]);
if pos(':210:',LineOfText)>0 then begin
substrings(LineOfText, ':' ,sList);
if (sList.Count=6) then
if (sList[3]='210') then writeln(Outfilehand,sList[0]+';'+sList[1]);
end;
end;
finally
sList.Free;
CloseFile (filehand);
CloseFile (Outfilehand);
end;
更新:
我理解了这个问题,因此您只对具有210
字段值的行感兴趣。如果您想要新文件中的所有行,请替换 .
if pos(':210:',LineOfText)>0 then begin
substrings(LineOfText, ':' ,sList);
if (sList.Count=6) then
if (sList[3]='210') then writeln(Outfilehand,sList[0]+';'+sList[1]);
end;
和
substrings(LineOfText, ':' ,sList);
if (sList.Count=6) then
if (sList[3]='210') then
writeln(Outfilehand,sList[0]+';'+sList[1]+';'+sList[4]+';'+sList[5]);
if (sList.Count=3) then
writeln(Outfilehand,sList[0]+';'+sList[1]);
基于 sList[3] 的大小或值:
- 您可以自行定义写入哪些字段
FSTRING.txt
。
更新2:
我会怎么做。
var
ParsedText : String;
inList,outList,sList : TStringList;
i:integer;
function SubStrings(lineText: String; var sList: TStringList):String;
begin
result:='ERROR';
lineText:=StringReplace(lineText,': ',':',[rfReplaceAll]);
lineText:=StringReplace(lineText,' :',':',[rfReplaceAll]);
sList.text:=StringReplace(lineText,':',#13#10,[rfReplaceAll]);
if (sList.Count=6) then
if (sList[3]='210') then result:=sList[0]+';'+sList[1]+';'+sList[4]+';'+sList[5] else
result:=sList[0]+';'+sList[1];
if (sList.Count=3) then result:=sList[0]+';'+sList[1];
end;
begin
inList := TStringList.Create;
outList := TStringList.Create;
sList := TStringList.Create;
try
inList.LoadFromFile('EMP.txt');
for i:= 0 to inList.Count-1 do begin
ParsedText := SubStrings(inList[i],sList);
if ParsedText <> 'ERROR' then outList.Add(ParsedText);
end;
outList.SaveToFile('FSTRING.txt');
finally
inList.Free;
outList.Free;
sList.Free;
end;
end;