2013-08-27 15:14:44 +04:00
|
|
|
#!/bin/bash
|
|
|
|
# -*- coding: utf-8 mode: sh -*- vim:sw=4:sts=4:et:ai:si:sta:fenc=utf-8
|
|
|
|
|
|
|
|
if [ "$#" -eq 1 -a "$1" == --nutools-makelinks ]; then
|
|
|
|
# créer les liens
|
|
|
|
scriptname="$(basename "$0")"
|
2014-01-21 11:35:07 +04:00
|
|
|
for alias in awkrun awkfsv2csv awkcsv mergecsv sortcsv; do
|
2013-08-27 15:14:44 +04:00
|
|
|
ln -s "$scriptname" "$alias"
|
|
|
|
done
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
|
|
|
|
source "$(dirname "$0")/ulib/ulib" &&
|
|
|
|
urequire DEFAULTS awk ||
|
|
|
|
exit 1
|
|
|
|
|
|
|
|
if [ "$scriptname" == "awkcsv" ]; then
|
|
|
|
[ $# -eq 1 -a "$1" == --help ] && exit_with uecho "$scriptname: wrapper autour de awk pour traiter des fichier csv
|
|
|
|
note: ce script ne tient pas compte de la locale: il travaille avec LANG=C
|
|
|
|
|
|
|
|
USAGE
|
2014-01-21 11:51:02 +04:00
|
|
|
$scriptname [-b before] -e script [-a after] [headers...] [-- inputfiles...]
|
2013-08-27 15:14:44 +04:00
|
|
|
|
|
|
|
$__AWKCSV_HELP"
|
|
|
|
|
|
|
|
cawkcsv "$@"
|
|
|
|
|
2014-01-21 11:35:07 +04:00
|
|
|
elif [ "$scriptname" == "awkfsv2csv" ]; then
|
|
|
|
[ $# -eq 1 -a "$1" == --help ] && exit_with uecho "$scriptname: wrapper autour de awk pour transformer un fichier à colonnes fixes en fichier csv
|
|
|
|
note: ce script ne tient pas compte de la locale: il travaille avec LANG=C
|
|
|
|
|
|
|
|
USAGE
|
2014-01-21 11:51:02 +04:00
|
|
|
$scriptname [header:sizes...] [-- inputfiles...]
|
2014-01-21 11:35:07 +04:00
|
|
|
|
|
|
|
$__AWKFSV2CSV_HELP"
|
|
|
|
|
|
|
|
cawkfsv2csv "$@"
|
|
|
|
|
2013-08-27 15:14:44 +04:00
|
|
|
elif [ "$scriptname" == "mergecsv" ]; then
|
|
|
|
[ $# -eq 1 -a "$1" == --help ] && exit_with uecho "$scriptname: fusionner deux fichiers csv sur un champ commun
|
|
|
|
note: ce script ne tient pas compte de la locale: il travaille avec LANG=C
|
|
|
|
|
|
|
|
USAGE
|
|
|
|
$scriptname [options] left right -k field
|
|
|
|
|
|
|
|
$__MERGECSV_HELP"
|
|
|
|
|
|
|
|
cmergecsv "$@"
|
|
|
|
|
|
|
|
elif [ "$scriptname" == "sortcsv" ]; then
|
|
|
|
[ $# -eq 1 -a "$1" == --help ] && exit_with uecho "$scriptname: trier un fichier csv sur un champ
|
|
|
|
note: ce script ne tient pas compte de la locale: il travaille avec LANG=C
|
|
|
|
|
|
|
|
USAGE
|
|
|
|
$scriptname [options] input -k field
|
|
|
|
|
|
|
|
$__SORTCSV_HELP"
|
|
|
|
|
|
|
|
csortcsv "$@"
|
|
|
|
|
|
|
|
else
|
|
|
|
[ $# -eq 1 -a "$1" == --help ] && exit_with uecho "$scriptname: wrapper autour de awk rajoutant des fonctions supplémentaires
|
|
|
|
note: ce script ne tient pas compte de la locale: il travaille avec LANG=C
|
|
|
|
|
|
|
|
USAGE
|
|
|
|
$scriptname [var=value...] script [-- inputfiles...]
|
|
|
|
|
|
|
|
Lancer awk avec un script préparé de la manière spécifiée ci dessous.
|
|
|
|
|
|
|
|
$__AWKDEF_HELP"
|
|
|
|
|
|
|
|
cawkrun -f "$@"
|
|
|
|
fi
|