私は Perl を初めて使用し、この言語でコーディングする方法をまだ理解しようとしています。
現在、csv の長い単一文字列を複数の行に分割しようとしています。
データ例
a,b,c<br />x,y,x<br />
これまでのところ、分割して引用符で囲み、後でもう一度CSVファイルに追加することができました:
"a,b,c""x,y,z"
引用符を使用することで、どの CSV セットがまとめられているかを示すだけです。
私が抱えている問題は、CSV ファイルを作成しようとすると、文字列でデータを渡すときにエラーが発生することです。
「未定義の変数に対してメソッド「parse」を呼び出すことはできません。
渡した文字列を印刷すると、それが定義され、データが保持されます。これは、経験不足で間違っている単純なものであることを願っています。
私が使用しているCSVコードは次のとおりです。
use warnings;
use Text::CSV;
use Data::Dumper;
use constant debug => 0;
use Text::CSV;
print "Running CSV editor......\n";
#my $csv = Text::CSV->new({ sep_char => ',' });
my $file = $ARGV[0] or die "Need to get CSV file on the command line\n";
my $fileextension = substr($file, -4);
#If the file is a CSV file then read in the file.
if ($fileextension =~ m/csv/i)
{
print "Reading and formating: $ARGV[0] \n";
open(my $data, '<', $file) or die "Could not open '$file' $!\n";
my @fields;
my $testline;
my $line;
while ($line = <$data>)
{
#Clears the white space at the end of the line.
chomp $line;
#Splits the line up and removes the <br />.
$testline = join "\" \" ", split qr{<br\s?/>}, $line;
#my $newStr = join $/, @lines;
#print $newStr;
my $q1 = "\"";
$testline = join "", $q1,$testline,$q1;
print "\n printing testline: \n $testline \n";
}
$input_string = $testline;
print "\n Testing input string line:\n $input_string";
if ($csv->parse ($input_string))
{
my @field = $csv->fields;
foreach my $col (0 .. $#field) {
my $quo = $csv->is_binary ($col) ? $csv->{quote_char} : "";
printf "%2d: %s%s%s\n", $col, $quo, $field[$col], $quo;#
}
}
else
{
print STDERR "parse () failed on argument: ",
$csv->error_input, "\n";
$csv->error_diag ();
}
#print $_,$/ for @lines;
print "\n Finished reading and formating: $ARGV[0] \n";
}else
{
print "Error: File is not a CSV file\n"
}