File: renderdoc2sqlite.pl

package info (click to toggle)
glgrib 1.0-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,861,476 kB
  • sloc: cpp: 20,811; ansic: 6,530; perl: 2,902; sh: 513; makefile: 147; python: 58; sql: 18
file content (45 lines) | stat: -rwxr-xr-x 894 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
#!/usr/bin/perl -w

use strict;
use DBI;
use File::Basename;
use FileHandle;
use Data::Dumper;


sub getline
{
  my $fh = shift;
  my $line = <$fh>;
  return () unless ($line);
  chomp ($line);
  my @line = split (m/\,\s*/o, $line);
  return @line;
}


my $f = shift;
my $b = &basename ($f, qw (.csv));

my $dbh = 'DBI'->connect ("DBI:SQLite:$b.db", '', '', {RaiseError => 1}) 
 or die ($DBI::errstr);
$dbh->{RaiseError} = 1;

my $fh = 'FileHandle'->new ("<$f");

my @h = map { (my $h = $_) =~ s/\W/_/go; $h } &getline ($fh);

$dbh->do ("CREATE TABLE IF NOT EXISTS $b (" . join (', ', map { "$_ REAL" } @h) . ");");

$dbh->do ("BEGIN TRANSACTION;");

my $sth = $dbh->prepare ("INSERT INTO $b VALUES (" . join (', ', map { '?' } @h) . ");");

while (my @line = &getline ($fh)) 
  {
    next if (grep { $_ eq 'Restart' } @line);
    $sth->execute (@line);
  }

$dbh->do ("COMMIT TRANSACTION;");