faire un fichier A (en éliminant les 10 premières lignes) afin que chaque ligne ne contienne que les 6 valeurs (virer les espaces, les virgules).
Réinjecter ces données dans un nouveau fichier Excel de telle manière que chaque ligne du nouveau fichier Excel contiennent 6 cellules avec 1 valeur par cellule !
(Remarque : les valeurs pour chaque ligne du fichier Excel de départ sont contenues dans 1 ou 3 cellules).
faire un fichier A (en éliminant les 10 premières lignes) afin que chaque ligne ne contienne que les 6 valeurs (virer les espaces, les virgules). Virer les 10 premières lignes ça j'ai compris et c'est faisable, par contre virer les virgules et les espaces ???
Réinjecter ces données dans un nouveau fichier Excel de telle manière que chaque ligne du nouveau fichier Excel contiennent 6 cellules avec 1 valeur par cellule ! Avec le bout de fichier du dessus, peux-tu nous mettre un exemple de ce que tu attends en sortie s'il te plaît, cmerci.
Tu tiens absolument à faire ce traitement en Perl ? Parce que le spécialiste maison (lami20j) est absent pour 1 mois ;-((
non pas nécessairement, je peux travailler directement sur le fichier txt (la réinjection des données dans un nouveau tableau Excel n'est pas primordiale)
dans ce cas : à partir du fichier txt ci-dessus (appelons le fichier A) obtenir un nouveau fichier (appelons le fichier B) ne contenant que les lignes qui contiennent les 6 valeurs avec par exemple un espace entre chaque valeur.
Ainsi je peux retravailler sur ce nouveau fichier (manipuler, extraire les données)
Excellent Mister Jipicy !!!!
Bien évidemment je pensais à quelque chose comme sed ou autre ! Je pense que ça m'ira pour le moment !
Je ne valide pas comme résolu car je pense qu'il y aura quelques détails à mettre au point .....
et j'aurai souhaité : 1 seul espace (ou une virgule ...je sais pas encore) entre chaque valeur d'une même ligne !
Je me dit que lorsque je travaillerai sur ce fichier final, c'est peut-être mieux d'homogénéiser, non ?
Mais peut-être que ça ne posera pas de problème non plus ?
ça me donne ceci (j'ai fait un copier-coler de ton exemple) :
[zozo@localhost Reception]$
./bob.sh
Usage : ./bob.sh <titi.txt> <tyty.txt>
[zozo@localhost Reception]$
Là je teste sur ma Mandriva !
je ne suis pas un expert de la programmation shell et de l'écriture de scripts bash ( je comprends pas les deux premières lignes de ton script !) mais il me semble avoir lu un post sur CCM ou tu proposais une solution de script avec Usage
....je vais essayer de retrouver ça (c'était clair et limpide !) :-))
tiens J'ai trouvé ceci :
http://abs.traduc.org/abs-4.2.01-fr/index.html
je crois que c'est pour ma pomme !!!!
Le script doit être lancé avec 2 fichiers en paramètres, le fichier d'entrée et le fichier de sortie. Donc la 1ère ligne :
if [ "$#" -lt "2" -o "$#" -gt "2" ]
teste l'existence des 2 paramètres, "$#" renvoie le nombre de paramètres.
La 1ère expression ("$#" -lt "2") teste si le nombre de paramètre est inférieur à 2 et la 2nd ("$#" -gt "2") s'il est supérieur à 2, dans l'une ou l'autre des situations, on affiche la façon dont doit être lancé le script :
then
echo "Usage : $0 <fichier.entrée> <fichier.sortie>"
echo
exit 2
fi
ok ! merci pour la seconde méthode ! Je prends aussi afin de l'étudier !
Une dernière question : est-il possible (au point ou en est ) par une programmation shell (en utilsant sed, awk ou que sais-je encore) de :
Récupérer des données d'un fichier Excel A et de réinjecter ces données dans un fichier Excel B !
je m'explique : le fichier Excel A contient n lignes (chaque ligne contient 6 valeurs) ! Le problème est que pour chaque ligne les 6 valeurs sont contenues dans 1 seule cellule !
Le but du jeu c'est d'avoir un fichier Excel B avec pour chaque ligne 1 seule valeur contenue dans 1 cellule (plus pratique pour qu'ensuite l'utilsateur puisse faire son travail).
Ben je suppose que oui, mais faut me donner le fichier d'entrée (A) et l'exemple en sortie (B), histoire qu'on se comprenne bien sur ce qu'il faut faire ;-))
ben le mieux est de t'envoyer le fichier d'entrée (Excel) ! tu verras mieux comme ça !
Pour le fichier de sortie (Excel aussi) c'est "tout bête" :
pour chaque ligne du fichier sortie chaque valeur doit se retrouver dans une cellule (soit 6 cellules par ligne puisqu'il y a 6 valeurs)
comme tu le verras sur le fichier d'entrée (Excel) les 6 valeurs sont contenues dans une même et grande cellule (1ère colonne) !
Tout ce que tu m'a appris ce soir va me servir beaucoup !
En fait j'anticipe en jouant sur les 2 tableaux (1 fichier Excel retravaillé pour l'utilisateur et des fichiers plats pour des manipulations de données plus poussées) :-))
@++
PS : j'ai essayé le script bob.sh directement sur des fichiers .xls ....juste pour voir ......et ....ça semble "marcher" bien que le fichier sortie soit illisible !
Des réglages à faire .... :-)
comme tu le vois pour chaque ligne : les 6 valeurs sont dans une seule et même cellule.
Le but du jeu :
- virer les 9 premières lignes du fichier entrée qui ne servent à rien !
- virer les virgules, formater.
- réinjecter les données dans un fichier excel sortie avec pour chaque ligne : 1 valeur par cellule (soit 6 cellules pour chaque ligne).
Tu es .....................Super ! C'est exactement ça !
:-))
Bigre !
La programmation shell ......c'est chouette tout de même (voir puissant ! ).
Et tout ce que je demandais tiens en ..............une demi-ligne : excellent !
Tu es vraiment formidable ! :-))
Y a plus qu'à prendre exemple !
Tu tiens absolument à faire ce traitement en Perl
non pas nécessairement, je peux travailler directement sur le fichier txt (la réinjection des données dans un nouveau tableau Excel n'est pas primordiale)
dans ce cas : à partir du fichier txt ci-dessus (appelons le fichier A) obtenir un nouveau fichier (appelons le fichier B) ne contenant que les lignes qui contiennent les 6 valeurs avec par exemple un espace entre chaque valeur.
Ainsi je peux retravailler sur ce nouveau fichier (manipuler, extraire les données)
Merci à toi.
Bob