logo Debian Debian Debian-France Debian-Facile Debian-fr.org Forum-Debian.fr Debian ? Communautés logo inclusivité

Debian-facile

Bienvenue sur Debian-Facile, site d'aide pour les nouveaux utilisateurs de Debian.

Vous n'êtes pas identifié(e).


L'icône rouge permet de télécharger chaque page du wiki visitée au format PDF et la grise au format ODT → ODT PDF Export

Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentes Révision précédente
Prochaine révision
Révision précédente
Prochaine révision Les deux révisions suivantes
doc:systeme:commandes:les-commandes-join-paste-split-et-nl [06/08/2014 17:51]
Hypathie [sort]
doc:systeme:commandes:les-commandes-join-paste-split-et-nl [27/05/2015 15:21]
captnfab [La commande join]
Ligne 132: Ligne 132:
    
 ===Affichage numéroté === ===Affichage numéroté ===
-<​code>​+<​code ​user>
 nl ~/​Essai-text-processing/​bashrc-bis nl ~/​Essai-text-processing/​bashrc-bis
-</​code ​user>+</​code>​
  
 <​code>​ <​code>​
-     1 # ~/.bashrc: executed by bash(1) for non-login shells. +1 # ~/.bashrc: executed by bash(1) for non-login shells. 
-     ​2 # see /​usr/​share/​doc/​bash/​examples/​startup-files (in the package bash-doc) +2 # see /​usr/​share/​doc/​bash/​examples/​startup-files (in the package bash-doc) 
-     ​3 # for examples +3 # for examples 
-       ​ +  
-     ​4 # If not running interactively,​ don't do anything +4 # If not running interactively,​ don't do anything 
-     ​5 case $- in +5 case $- in 
-     ​6     *i*) ;; +6     *i*) ;; 
-     ​7       *) return;; +7       *) return;; 
-     ​8 esac +8 esac
 </​code>​ </​code>​
  
Ligne 183: Ligne 182:
 =====La commande join ===== =====La commande join =====
 ===Syntaxe de la commande join === ===Syntaxe de la commande join ===
-<​code ​user>+<​code>​
 join [options]... fichier1 fichier2 join [options]... fichier1 fichier2
 </​code>​ </​code>​
Ligne 210: Ligne 209:
 ===Fusion de ces deux fichiers === ===Fusion de ces deux fichiers ===
  
-<​code>​+<​code ​user>
 join -1 1 -2 2 ~/​Essai-text-processing/​users ~/​Essai-text-processing/​infos-users join -1 1 -2 2 ~/​Essai-text-processing/​users ~/​Essai-text-processing/​infos-users
 </​code>​ </​code>​
Ligne 295: Ligne 294:
 03 Lili lili@hotmail.com 03 03 Lili lili@hotmail.com 03
 </​code>​ </​code>​
- 
-===== sort ===== 
-===Syntaxe=== 
- 
-  sort [options [+POS1] [-POS2]] [fichier...] 
- 
-<note tip> 
-__La commande sort permet__ : 
- 
-  * d'​afficher le contenu de fichiers ; 
-  * de trier les lignes d'un fichier texte, en fonction des colonnes. 
-__ 
-Les options utiles__: 
- 
-  * **''​-o''​** : inscrire la sortie dans un fichier 
-  * **''​-t''​** : pour spécifier le séparateur (par défaut ce sont les espaces ou les tabulations qui délimitent les colonnes) 
-  * **''​-k''​** : pour spécifier la colonne (à la place de +POS1 -POS2) 
-  * **''​-n''​** : pour spécifier qu'il s'agit d'un tri numérique 
-  * **''​-d''​** : pour tri dictionnaire 
-  * **''​-r''​** : pour un tri inverse (-rn [inverse de numérique] ou -rd [inverse d'​alphabétique]) 
-  * **''​-M''​** : ordre chronologique 
-  * **''​-h''​** : comparer des nombres dans un format lisible par un  humain (par exemple, 2K 1G) 
-  * **''​-f''​** : (ignore-case) convertir les minuscules en majuscule 
- 
-Voir man sort pour les autres options. 
-</​note>​ 
- 
-====Affichage de plusieurs fichiers avec sort ==== 
- 
-  * Comparaison avec la commande cat : 
-<code user> 
-cat sort1.txt 
-</​code>​ 
-<​code>​ 
-5 1 Amandine 
-1 7 Bruno  
-3 2 Caroline 
-</​code>​ 
-<code user> 
-cat sort2.txt 
-<​code>​=== 
-2 5 Daniel 
-2 6 Émilien 
-0 3 Fabrice 
-0 4 Guillaume 
-</​code>​ 
- 
->Dans chacun de ses deux fichiers, les lignes ne sont pas rangées en fonction des colonnes 
- 
-<code user> 
-sort sort1.txt sort2.txt 
-</​code>​ 
-<​code>​ 
-0 3 Fabrice 
-0 4 Guillaume 
-1 7 Bruno  
-2 5 Daniel 
-2 6 Émilien 
-3 2 Caroline 
-5 1 Amandine 
-</​code>​ 
- 
->Même sans option, les deux fichiers ont été concaténés et leurs lignes rangées par ordre numérique croissant en fonction de la première colonne. 
->Si des doublons apparaissent dans la première colonne pour deux lignes consécutives,​ ces deux lignes seront rangées en fonction de leur deuxième colonne. 
- 
-====Enregistrer le résultat : option -o ==== 
- 
-  * Concaténer "​sort1.txt"​ et "​sort2.txt"​ et inscrire le résultat dans un fichier : 
- 
-<code user> 
-sort -o sort3.txt sort1.txt sort2.txt 
-</​code>​ 
- 
-<code user> 
-cat sort3.txt 
-</​code>​ 
-<​code>​ 
-0 3 Fabrice 
-0 4 Guillaume 
-1 7 Bruno  
-2 5 Daniel 
-2 6 Émilien 
-3 2 Caroline 
-5 1 Amandine 
-</​code>​ 
- 
-====Trier selon un ordre alphabétique d'une colonne : option -d==== 
- 
- 
-  * soit le fichier "​alpha-sort.txt"​ déjà trié par ordre numérique selon les colonnes 1 et 2 pour les doublons : 
- 
-<code user> 
-cat alpha-sort.txt 
-</​code>​ 
-<​code>​ 
-1 2 Francine 
-2 3 Édith 
-3 4 Géraldine 
-4 5 Béatrice 
-5 6 Christelle 
-5 7 Dorothée 
-6 8 Amanda 
-</​code>​ 
- 
-  * Pour le trier selon l'​ordre alphabétique d'une colonne : 
-Si on indique le type (numérique ou alphabétique),​ c'est que le type de la première colonne ne nous intéresse pas.\\ ​ 
-Par exemple ici, le fichier est rangé selon l'​ordre numérique selon ses colonnes 1 et 2. 
-<code user> 
-sort -k3d alpha-sort.txt 
-</​code>​ 
-<​code>​ 
-6 8 Amanda 
-4 5 Béatrice 
-5 6 Christelle 
-2 3 Édith 
-5 7 Dorothée 
-1 2 Francine 
-3 4 Géraldine 
-</​code>​ 
- 
-> l'​option -k pour indiquer qu'on va utiliser une colonne spécifique pour le tri; 
->3 pour spécifier le n° de colonne 
->d pour spécifier le type de tri "​dictionnaire"​ ou ordre alphabétique 
- 
-====Trier selon l'​ordre numérique d'une colonne==== 
-  * soit le fichier "​sort.txt"​ : 
- 
-<code user> 
-cat sort.txt 
-</​code>​ 
-<​code> ​ 
-pomme 2 
-fraise 6 
-abricot 9 
-kiwi 3 
-</​code>​ 
- 
-  * Pour ordonner ce fichier selon l'​ordre numérique de la deuxième colonne : 
- 
-<code user> 
-sort -k2n sort.txt 
-</​code>​ 
- 
-<​code>​ 
-pomme 2 
-kiwi 3 
-fraise 6 
-abricot 9 
-</​code>​ 
- 
-<note tip> 
-Si on avait voulu ranger ce fichier selon l'​ordre alphabétique,​ il aurait suffi de faire : 
- 
-  sort sort.txt ​ 
- 
-Il aurait été inutile d'​indiquer la colonne car la première colonne comporte des chaînes de caractères.\\ ​ 
- 
-Comme vous l'​aurez compris, par défaut, sort trie en fonction de la colonne n°1 selon le type qui est le sien, puis s'il faut, en fonction de la colonne n° 2, et du type qui est celui de cette deuxième colonne.\\ ​ 
- 
-En fait, sed s'​adapte automatiquement au type du contenu de la première colonne, voire au type du contenu de la seconde colonne pour départager éventuellement les doublons de cette première colonne, même si les types diffèrent d'une colonne à l'​autre.\\ ​ 
-</​note>​ 
- 
-====Tri par défaut d'un fichier dont les colonnes présentent plusieurs types==== 
- 
-  * Soit fichier "​xxx-sort.txt"​ désordonné selon ses types : 
-<code user> 
-cat xxx-sort.txt ​ 
-</​code>​ 
-<​code>​ 
-10 fraise 
-pomme 6 
-Titi grosminet 
-25 8 
-</​code>​ 
-  * Par défaut, sort trie selon l'​ordre numérique d'​abord puis par ordre alphabétique :  
-<code user> 
-sort xxx-sort.txt 
-</​code>​ 
-<​code> ​ 
-10 fraise 
-25 8 
-pomme 6 
-Titi grosminet 
-</​code>​ 
- 
-  * de même pour l'​autre colonne : 
-<​code>​ 
-sort -k2 xxx-sort.txt 
-</​code>​ 
-<​code>​ 
-pomme 6 
-25 8 
-10 fraise 
-Titi grosminet 
-</​code>​ 
- 
- 
-====Trier selon plusieurs colonnes et différents types ==== 
- 
-  * Soit le fichier "​sort4.txt"​ qui est un extrait du fichier **/​etc/​passwd** dont j'ai pris quelques lignes que ai interverties pour cet exemple : 
-<code user> 
-cat sort4.txt 
-</​code>​ 
-<​code>​ 
-daemon:​x:​1:​1:​daemon:/​usr/​sbin:/​bin/​sh 
-root:​x:​0:​0:​root:/​root:/​bin/​bash 
-man:​x:​6:​12:​man:/​var/​cache/​man:/​bin/​sh 
-bin:​x:​2:​2:​bin:/​bin:/​bin/​sh 
-news:​x:​9:​9:​news:/​var/​spool/​news:/​bin/​sh 
-sync:​x:​4:​65534:​sync:/​bin:/​bin/​sync 
-games:​x:​5:​60:​games:/​usr/​games:/​bin/​sh 
-mail:​x:​8:​8:​mail:/​var/​mail:/​bin/​sh 
-lp:​x:​7:​7:​lp:/​var/​spool/​lpd:/​bin/​sh 
-sys:​x:​3:​3:​sys:/​dev:/​bin/​sh 
-</​code>​ 
- 
- 
-  * Pour faire un tri selon le shell des utilisateurs (7ième colonnes : type "​dictionnaire"​) et en cas de doublon pour cette colonne, en fonction ensuite de l'UID (3ième colonne : type "​numérique"​) 
- 
-<code user> 
-sort -t':'​ -k 7d -k 3n sort4.txt 
-</​code>​ 
- 
-> **''​-t':'​ ''​** pour spécifier le séparateur **'':''​** (par défaut c'est l'​espace ou la tabulation, il faut donc indiquer le séparateur pour les fichiers de type.) 
-> **''​-k''​** ​ pour indiquer les colonnes souhaitées 
-> **''​7d''​** ​ pour **7**ième colonne type "​**d**ictionnaire"​ 
-> **''​3n''​** ​ pour **3**ième colonne type "​**n**umérique"​ 
- 
-<​code>​ 
-root:​x:​0:​0:​root:/​root:/​bin/​bash 
-daemon:​x:​1:​1:​daemon:/​usr/​sbin:/​bin/​sh 
-bin:​x:​2:​2:​bin:/​bin:/​bin/​sh 
-sys:​x:​3:​3:​sys:/​dev:/​bin/​sh 
-games:​x:​5:​60:​games:/​usr/​games:/​bin/​sh 
-man:​x:​6:​12:​man:/​var/​cache/​man:/​bin/​sh 
-lp:​x:​7:​7:​lp:/​var/​spool/​lpd:/​bin/​sh 
-mail:​x:​8:​8:​mail:/​var/​mail:/​bin/​sh 
-news:​x:​9:​9:​news:/​var/​spool/​news:/​bin/​sh 
-sync:​x:​4:​65534:​sync:/​bin:/​bin/​sync 
-</​code>​ 
- 
  
  
doc/systeme/commandes/les-commandes-join-paste-split-et-nl.txt · Dernière modification: 06/11/2015 17:57 par paskal

Pied de page des forums

Propulsé par FluxBB