/[virtual-ldap]/bin/csv2yaml.pl
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /bin/csv2yaml.pl

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 9 by dpavlin, Sun Mar 15 19:45:44 2009 UTC revision 26 by dpavlin, Mon Mar 16 14:58:54 2009 UTC
# Line 11  use Data::Dump qw/dump/; Line 11  use Data::Dump qw/dump/;
11  use File::Slurp;  use File::Slurp;
12  use YAML qw/DumpFile/;  use YAML qw/DumpFile/;
13  use Text::CSV;  use Text::CSV;
14  use Encode qw/decode/;  use Encode qw/from_to/;
15    
16  my $debug = 0;  my $debug = 0;
17    
18  my $path = shift @ARGV || die "usage: $0 file.csv\n";  my $path = shift @ARGV || die "usage: $0 file.csv\n";
19    
20  my $csv = read_file( $path );  my $csv = read_file( $path );
21  $csv = decode('utf-16', $csv);  from_to($csv, 'utf-16', 'utf-8');
22    
23  my @columns;  my @columns;
24    
# Line 37  foreach my $line ( split(/\r?\n/, $csv) Line 37  foreach my $line ( split(/\r?\n/, $csv)
37    
38          warn "# fields = ",dump( @fields ) if $debug;          warn "# fields = ",dump( @fields ) if $debug;
39    
40          $hash->{ $columns[$_] } = $fields[$_] foreach ( 0 .. $#fields );          foreach ( 0 .. $#fields ) {
41                    my $n = $columns[$_];
42                    my $v = $fields[$_];
43    
44                    $v =~ s{\s*#\s*$}{};
45                    $v =~ s{^\s+}{};
46                    $v =~ s{\s+$}{};
47    
48                    # fix tel fields
49                    $v =~ s{\s+}{#}g if $n =~ m{tel};
50                    $v =~ s[\xC5\xBD][F]i if $n =~ m{spol};
51    
52                    if ( $v =~ m{#} ) { # subfields delimiter in CSV data
53                            my @v = split(/\s*#+\s*/, $v);
54                            foreach my $pos ( 0 .. $#v ) {
55                                    if ( $n =~ m{tel} ) {
56                                            if ( $v[$pos] =~ m{^09} ) {
57                                                    $hash->{ $n . '_mobile' } ||= $v[$pos];
58                                            } else {
59                                                    $hash->{ $n . '_fixed' } ||= $v[$pos];
60                                            }
61                                    }
62                                    $hash->{ $n . '_' . $pos } = $v[$pos];
63                            }
64    
65                            $hash->{ $n } = [ @v ];
66                    } else {
67                            $hash->{ $n } = $v;
68                    }
69            }
70    
71          warn dump( $hash ) if $debug;          warn dump( $hash ) if $debug;
72    

Legend:
Removed from v.9  
changed lines
  Added in v.26

  ViewVC Help
Powered by ViewVC 1.1.26