|
|
|
|
|
|
|
|
|
|
|
use strict; |
|
|
|
my $minChars = $ARGV[0]; |
|
my $maxChars = $ARGV[1]; |
|
my $inputStem = $ARGV[2]; |
|
my $source = $ARGV[3]; |
|
my $target = $ARGV[4]; |
|
my $outputStem = $ARGV[5]; |
|
my $linesRetained = $ARGV[6]; |
|
|
|
open(IN_SOURCE, "<:encoding(UTF-8)", "$inputStem.$source") or die "cannot open $inputStem.$source"; |
|
open(IN_TARGET, "<:encoding(UTF-8)", "$inputStem.$target") or die "cannot open $inputStem.$target"; |
|
|
|
open(OUT_SOURCE, ">:encoding(UTF-8)", "$outputStem.$source") or die "cannot open $outputStem.$source"; |
|
open(OUT_TARGET, ">:encoding(UTF-8)", "$outputStem.$target") or die "cannot open $outputStem.$target"; |
|
|
|
open(LINE_RETAINED, ">:encoding(UTF-8)", "$linesRetained"); |
|
|
|
my $lineNum = 0; |
|
while (my $lineSource = <IN_SOURCE>) { |
|
++$lineNum; |
|
|
|
|
|
chomp($lineSource); |
|
my $lineTarget = <IN_TARGET>; |
|
chomp($lineTarget); |
|
|
|
my $lenSource = length($lineSource); |
|
my $lenTarget = length($lineTarget); |
|
|
|
if ($lenSource < $minChars || $lenSource > $maxChars |
|
|| $lenTarget < $minChars || $lenTarget > $maxChars) { |
|
|
|
} |
|
else { |
|
print OUT_SOURCE "$lineSource\n"; |
|
print OUT_TARGET "$lineTarget\n"; |
|
print LINE_RETAINED "$lineNum\n"; |
|
} |
|
} |
|
|
|
close(OUT_SOURCE); |
|
close(OUT_SOURCE); |
|
close(LINE_RETAINED); |
|
|