csvファイルに基づいて画像の名前をバッチで変更およびコピーするスクリプトに取り組んでいます。csv は、列 1: 古い名前と列 2: 新しい名前で構成されます。csv ファイルを perl スクリプトの入力として使用して、古い名前をチェックし、新しい名前を使用してコピーを新しいフォルダーに作成したいと考えています。私が抱えている(と思う)問題は、画像に関係しています。それらには ß などの utf8 文字が含まれています。スクリプトを実行すると、次のように出力されます:
Unsuccessful stat on filename containing newline at C:/Perl64/lib/File/Copy.pm line 148, <$INFILE> line 1.
Copy failed: No such file or directory at X:\Script directory\correction.pl line 26, <$INFILE> line 1.
私はそれが Binmode utf8 と関係があることを知っていますが、単純なスクリプトを試しても (ここで見ました: How can I output UTF-8 from Perl? ):
use strict;
use utf8;
my $str = 'Çirçös';
binmode(STDOUT, ":utf8");
print "$str\n";
次のように表示されます: Ãirþ÷s
これは私のスクリプト全体です。どこが間違っているのか誰か説明してもらえますか? (私はものをテストしていたので、それは最もきれいなコードではありません)。
use strict;
use warnings;
use File::Copy;
use utf8;
my $inputfile = shift || die "give input!\n";
#my $outputfile = shift || die "Give output!\n";
open my $INFILE, '<', $inputfile or die "In use / not found :$!\n";
#open my $OUTFILE, '>', $outputfile or die "In use / not found :$!\n";
binmode($INFILE, ":encoding(utf8)");
#binmode($OUTFILE, ":encoding(utf8)");
while (<$INFILE>) {
s/"//g;
my @elements = split /;/, $_;
my $old = $elements[1];
my $new = "new/$elements[3]";
binmode STDOUT, ':utf8';
print "$old | $new\n";
copy("$old","$new") or die "Copy failed: $!";
#copy("Copy.pm",\*STDOUT);
# my $output_line = join(";", @elements);
# print $OUTFILE $output_line;
#print "\n"
}
close $INFILE;
#close $OUTFILE;
exit 0;