Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/songmu/p5-data-googlespreadsheet-fetcher
https://github.com/songmu/p5-data-googlespreadsheet-fetcher
Last synced: 28 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/songmu/p5-data-googlespreadsheet-fetcher
- Owner: Songmu
- Created: 2012-08-03T09:24:39.000Z (over 12 years ago)
- Default Branch: master
- Last Pushed: 2012-08-07T01:36:09.000Z (over 12 years ago)
- Last Synced: 2024-11-06T01:02:37.520Z (3 months ago)
- Language: Perl
- Size: 129 KB
- Stars: 1
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.pod
- Changelog: Changes
Awesome Lists containing this project
README
package Data::GoogleSpreadsheet::Fetcher;
use strict;
use warnings;
our $VERSION = '0.01_01';
$VERSION = eval $VERSION; ## no criticuse utf8;
use Net::Google::Spreadsheets;use Any::Moose;
has spreadsheet => (
is => 'ro',
isa => 'Net::Google::Spreadsheets::Spreadsheet',
lazy => 1,
default => sub {
my $self = shift;
Net::Google::Spreadsheets->new(
username => $self->username,
password => $self->password,
)->spreadsheet({
key => $self->key,
});
},
);has username => (
is => 'ro',
isa => 'Str',
);has password => (
is => 'ro',
isa => 'Str',
);has key => (
is => 'ro',
isa => 'Str',
);has config => (
is => 'ro',
isa => 'HashRef',
default => sub {{}},
);has ignore_empty => (
is => 'ro',
isa => 'Int',
default => sub {0},
);no Any::Moose;
sub fetch_worksheet {
my ($self, $table) = @_;
my $table_config = $self->config->{tables}{$table} || {};
my $sheet = $table_config->{sheet} || $table;# my $sheet = $self->spreadsheet->worksheet({title => $sheet}); # doesn't work
# because this interface is prefix search
my ($worksheet) = grep {$_->title eq $sheet} $self->spreadsheet->worksheets({title => $sheet});my $cond = $table_config->{cond} || {sq => 'id > 0'};
my @rows = map {$_->content} $worksheet->rows($cond);return $self->_process_rows($table, \@rows);
}sub _process_rows {
my ($self, $table, $rows) = @_;my $table_config = $self->config->{tables}{$table} || {};
my @columns = @{$table_config->{columns} || []};
unless (@columns) {
@columns = grep {/^[a-z]/} map {_replace_column4db($_)} keys %{$rows->[0]};
}
my @db_columns = (@columns, @{$table_config->{addtional_columns} || []});
my @table_rows;my %seen_id;
ROW:
for my $row (@$rows) {
next if !$row->{id} || $row->{id} !~ /^\d+$/;
!$seen_id{$row->{id}}++ or die "id $row->{id} is duplicated!";my %row_data;
for my $real_column (@db_columns) {
my $sheet_column = _replace_column4spreadsheet($real_column);my $data = _trim($row->{$sheet_column});
next if $self->ignore_empty && $data eq '';
$row_data{$real_column} = $data;
}my $filters = $table_config->{filter} || [];
my @filters = ref $filters eq 'ARRAY' ? @{$filters} :
ref $filters eq 'HASH' ? %{$filters} : ();while (my ($column, $rule) = splice @filters, 0, 2) {
$row_data{$column} =
!ref $rule ? $rule :
ref $rule eq 'CODE' ? $rule->(\%row_data) : '';
}my @validates =
grep {$_ && ref $_ eq 'CODE'}
($self->config->{global}{hooks}{row_validate}, $table_config->{row_validate});for my $validate (@validates) {
next ROW unless $validate->(\%row_data);
}push @table_rows, \%row_data;
}
@table_rows;
}sub _trim {
my ($string) = @_;return '' unless defined $string;
$string =~ s/^[\s ]+//;
$string =~ s/[\s ]+$//;$string;
}sub _replace_column4spreadsheet {
my ($column_name) = @_;$column_name =~ s/_/-/g;
$column_name;
}sub _replace_column4db {
my ($column_name) = @_;$column_name =~ s/-/_/g;
$column_name;
}__PACKAGE__->meta->make_immutable;
__END__
=head1 NAME
Data::GoogleSpreadsheet::Fetcher -
=head1 SYNOPSIS
use Data::GoogleSpreadsheet::Fetcher;
my $fetcher = Data::GoogleSpreadsheet::Fetcher->new(
username => 'username',
password => 'your_password_here',
key => 'spreadsheet key',
);
my @records = $fetcher->fetch_worksheet('sheet_name');=head1 DESCRIPTION
Data::GoogleSpreadsheet::Fetcher is
=head1 AUTHOR
Masayuki Matsuki [email protected]
=head1 SEE ALSO
=head1 LICENSE
This library is free software; you can redistribute it and/or modify
it under the same terms as Perl itself.=cut