Perl のアプローチに従います。
- 注 1: あまりよく書かれていませんが、適切に動作します
- 注2:私の答えは、「start_time」と「end_time」によって文字通り文字列を参照するのではなく、ある種のタイムスタンプなどを参照するという考慮に基づいています
どうぞ:
#!/usr/bin/perl
use warnings;
use strict;
my @waiting; #here we will keep track of the order
my %previous; #here we will save previous rows that still can't be printed
open (my $IN,'<','file.txt') or die "$!"; #assuming that your data is in file.txt
while (<$IN>) {
chomp;
my ($id,$time)=split/ /;
if (exists $previous{$id}) { #if this is the end_time
$previous{$id}->[1]=$time;
if ($waiting[0]==$id) { #if we are not waiting for another row's end_time
my $count=0;
for (@waiting) { #print anything you have available
last if !defined $previous{$_}->[1];
print join(' ',$x,@{$previous{$_}}),"\n";
delete $previous{$_};
$count++;
}
shift @waiting for 1..$count;
}
}
else { #if this is the start_time
push @waiting,$id;
$previous{$id}=[$time,undef];
}
}
close $IN;