The following lines of comma-separated values ββcontain several consecutive empty fields:
$rawData =
"2008-02-06,8:00 AM,14.0,6.0,59,1027,-9999.0,West,6.9,-,N/A,,Clear\n
2008-02-06,9:00 AM,16,6,40,1028,12,WNW,10.4,,,,\n"
I want to replace these empty fields with "N / A" values, so I decided to do this by replacing the regex.
I tried this in the first place:
$rawdata =~ s/,([,\n])/,N\/A/g;
who returned
2008-02-06,8:00 AM,14.0,6.0,59,1027,-9999.0,West,6.9,-,N/A,N/A,Clear\n
2008-02-06,9:00 AM,16,6,40,1028,12,WNW,10.4,N/A,,N/A,\n
Not what I wanted. A problem occurs when more than two consecutive commas occur. A regular expression pinches two commas at a time, so it starts with the third comma, not the second when it rescans a string.
I thought this could be due to lookahead or backback statements, so I tried the following expression:
$rawdata =~ s/(?<=,)([,\n])|,([,\n])$/,N\/A$1/g;
resulting in:
2008-02-06,8:00 AM,14.0,6.0,59,1027,-9999.0,West,6.9,-,N/A,,N/A,Clear\n
2008-02-06,9:00 AM,16,6,40,1028,12,WNW,10.4,,N/A,,N/A,,N/A,,N/A\n
That didn't work either. He just moved the commas to one.
, , . , . ?
:
2008-02-06,8:00 AM,14.0,6.0,59,1027,-9999.0,West,6.9,-,N/A,N/A,N/A,Clear\n
2008-02-06,9:00 AM,16,6,40,1028,12,WNW,10.4,,N/A,,N/A,N/A,N/A,N/A,N/A\n