From 30ee49ddb4e425191bb868e7b20789a8bb50f5ff Mon Sep 17 00:00:00 2001 From: Julian Maurice Date: Fri, 6 Jul 2012 12:31:48 +0200 Subject: [PATCH] Bug 8376: New script to export borrowers misc/export_borrowers.pl This script prints to standard output what is returned by GetMemberDetails in CSV format. Exported fields can be specified with option -f. If no -f option is specified, all fields are exported. Signed-off-by: Gaetan Boisson Signed-off-by: Robin Sheat Amended with some code to better handle bad data. Signed-off-by: Paul Poulain --- misc/export_borrowers.pl | 113 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 113 insertions(+) create mode 100755 misc/export_borrowers.pl diff --git a/misc/export_borrowers.pl b/misc/export_borrowers.pl new file mode 100755 index 0000000000..c4b3e401a7 --- /dev/null +++ b/misc/export_borrowers.pl @@ -0,0 +1,113 @@ +#!/usr/bin/perl + +# Copyright 2011 BibLibre +# +# This file is part of Koha. +# +# Koha is free software; you can redistribute it and/or modify it under the +# terms of the GNU General Public License as published by the Free Software +# Foundation; either version 2 of the License, or (at your option) any later +# version. +# +# Koha is distributed in the hope that it will be useful, but WITHOUT ANY +# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR +# A PARTICULAR PURPOSE. See the GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License along +# with Koha; if not, write to the Free Software Foundation, Inc., +# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. + +# Script to export borrowers + +use Modern::Perl; +use Text::CSV; +use Getopt::Long qw(:config no_ignore_case); + +use C4::Context; +use C4::Members; + +use encoding 'utf8'; + +sub print_usage { + ( my $basename = $0 ) =~ s|.*/||; + print < \@fields, + 'show-header|H' => \$show_header, + 'help|h' => \$help +) or print_usage, exit 1; + +if ($help) { + print_usage; + exit; +} + +# Getting borrowers +my $dbh = C4::Context->dbh; +my $query = "SELECT borrowernumber FROM borrowers ORDER BY borrowernumber"; +my $sth = $dbh->prepare($query); +$sth->execute; + +my $csv = Text::CSV->new( { binary => 1 } ); + +# If the user did not specify any field to export, we assume he wants them all +# We retrieve the first borrower informations to get field names +my ($borrowernumber) = $sth->fetchrow_array; +my $member = GetMemberDetails($borrowernumber); +@fields = keys %$member unless (@fields); + +if ($show_header) { + $csv->combine(@fields); + print $csv->string . "\n"; +} + +$csv->combine( + map { + ( defined $member->{$_} and !ref $member->{$_} ) + ? $member->{$_} + : '' + } @fields +); +die "Invalid character at borrower $borrowernumber: [" + . $csv->error_input . "]\n" + if ( !defined( $csv->string ) ); +print $csv->string . "\n"; + +while ( my $borrowernumber = $sth->fetchrow_array ) { + $member = GetMemberDetails($borrowernumber); + $csv->combine( + map { + ( defined $member->{$_} and !ref $member->{$_} ) + ? $member->{$_} + : '' + } @fields + ); + die "Invalid character at borrower $borrowernumber: [" + . $csv->error_input . "]\n" + if ( !defined( $csv->string ) ); + print $csv->string . "\n"; +} -- 2.39.5