On 04/06/2010, at 11.24, Martin Dupont Ahrentsen wrote:
Hejsa alle,
Nu har jeg efterprøvet flere af de løsninger som er blevet forslået.
1.
OLD_IFS=$IFS
IFS="|"
line=($i)
IFS=$OLD_IFS
testcustomerid=${line[0]}
teststartno=${line[1]}
testendno=${line[2]}
testactiveflag=${line[3]}
testprocflag001=${line[4]}
testprocflag002=${line[5]}
testprocflag003=${line[6]}
testprocflag004=${line[7]}
testcountrya2=${line[8]}
testzip=${line[9]}
testprocflag005=${line[10]}
Det gjorde at tiden blev skåret ned fra ~ 2 timer til 35 minutter
2.
TCL løsningen fik jeg desværre ikke til at virke efter hensigten.
3.
AWK løsningen som Kristian Duss Østergaard er klart vinderen. Process tiden her er nede på ca 1½ sekund!! Samtidig med at det var super let at integrere i det eksisterende script som også sørger for at distribuere output filen ud til ca 15 servere ved hjælp af awk -f <navn>.awk <inputfil> > <outputfil>.
BEGIN { FS="|";
IFS="|";
OFS="|";
startno1=92080000001;
endno1=92081327500;
startno2=92085000001;
endno2=92085135000;
startno3=92085135000;
endno3=92085973000;
}
($2>=startno1 && $3<=endno1) ||
($2>=startno2 && $3<=endno2) ||
($2>=startno3 && $3<=endno3) {
$6="Y";
$7="Y";
}
{print $0}
I skal alle ha tak for hjælpen.
Med venlig hilsen
Martin Ahrentsen
Rødkælkevej 53, Hadbjerg
8370 Hadsten
25241017
Hej Martin,
Det glæder mig at du kunne bruge den :-)
Hvis det er at du skal have splittet den oprindelige fil samtidig med at den laver denne behandlig kan jeg anbefale dig at kigge nærmere på sproget, da awk sagtens kan lade awk sende outputtet til fx. $1, men den må du selv lege med ;-)
Mvh.
Kristian Duus Østergaard