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 →
Ci-dessous, les différences entre deux révisions de la page.
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 [08/06/2014 05:56] Hypathie [La commande uniq] |
doc:systeme:commandes:les-commandes-join-paste-split-et-nl [08/06/2014 08:27] Hypathie [la commande fmt] |
||
---|---|---|---|
Ligne 362: | Ligne 362: | ||
=====La commande split ===== | =====La commande split ===== | ||
+ | ===Syntaxe === | ||
+ | |||
+ | split [options] [fichier_entrée [préfixe_sortie]] | ||
+ | |||
+ | ===Préparation === | ||
+ | Création du fichier "~/Essai-text-processing/liste-fruits" | ||
+ | |||
+ | <code user> | ||
+ | cat > ~/Essai-text-processing/liste-fruits <<EOF | ||
+ | > 1 fraise | ||
+ | > 2 abricot | ||
+ | > 3 pomme | ||
+ | > EOF | ||
+ | </code> | ||
+ | |||
+ | Vérification : | ||
+ | |||
+ | <code user> | ||
+ | cat ~/Essai-text-processing/liste-fruits | ||
+ | # Retour: | ||
+ | 1 fraise | ||
+ | 2 abricot | ||
+ | 3 pomme | ||
+ | </code> | ||
+ | ===Découpage en taille et répartition en autant de fichiers === | ||
+ | <note> | ||
+ | * options de découpage par taille :\\ | ||
+ | |||
+ | -C : découper par taille maximale\\ | ||
+ | ex: split -C 5 fichier : découpage en 5 octets\\ | ||
+ | ( ou de même split -C 5b)\\ | ||
+ | |||
+ | split -C 5k fichier : découpage en 5 kilo-octets\\ | ||
+ | split -C 5m fichier : découpage en 5 mega-octets\\ | ||
+ | -b : découper par 1 taille précise\\ | ||
+ | Ex: split -b 5 fichier) => tous les fichiers créés par découpage auront cette taille (sauf peut-être le dernier) | ||
+ | |||
+ | * Remarque:\\ | ||
+ | Il faut 8 bits pour faire 1 byte (1 octet) | ||
+ | - bit : c'est **Bi**naryDigi**T** : un bit est un chiffre binaire, la valeur d'un bit, c'est 0 ou 1. | ||
+ | - byte : terme anglais pour octet. L'ordinaire calcule sur un ou plusieurs byte. | ||
+ | </note> | ||
+ | |||
+ | * exemple de découpage par taille d'un octet avec le préfixe "fruit1b" | ||
+ | |||
+ | <code user> | ||
+ | split -C 1b ~/Essai-text-processing/liste-fruits fruit1b | ||
+ | </code> | ||
+ | Le fichier n'est pas lourd et le découpage en taille de 1 byte (=octet) ne le découpe pas : | ||
+ | <code user> | ||
+ | ls fruit1b* | ||
+ | # Retour | ||
+ | fruit1baa | ||
+ | </code> | ||
+ | |||
+ | Un seul fichier a été créé : | ||
+ | <code user> | ||
+ | cat fruit1b* | ||
+ | # Retour : | ||
+ | 1 fraise | ||
+ | 2 abricot | ||
+ | 3 pomme | ||
+ | </code> | ||
+ | Et le fichier et créé dans le répertoire dans lequel le terminal est ouvert.\ | ||
+ | Pour que le fichier créé lors du découpage soit dans le répertoire du fichier à découper : | ||
+ | |||
+ | <code user> | ||
+ | split -C 1b ~/Essai-text-processing/liste-fruits fruit1b && mv fruit1b* ~/Essai-text-processing/ | ||
+ | #puis | ||
+ | ls ~/Essai-text-processing/fruit1b* | ||
+ | # Retour: | ||
+ | /home/hypathie/Essai-text-processing/fruit1baa | ||
+ | </code> | ||
+ | Ou | ||
+ | <code user> | ||
+ | cd Essai-text-processing/ | ||
+ | # puis: | ||
+ | split -C 1b ~/Essai-text-processing/liste-fruits fruit1b | ||
+ | # puis : | ||
+ | ls fruit1b* | ||
+ | fruit1baa | ||
+ | </code> | ||
+ | |||
+ | ===Découpage par ligne === | ||
+ | <note> | ||
+ | * option de découpage par ligne qui détermine le découpage :\\ | ||
+ | -l : pour indiquer le nombre de ligne\\ | ||
+ | |||
+ | * Remarque :\\ | ||
+ | Sans indication de préfixe, par défaut les fichiers créés par le découpage porte le préfixe x?? | ||
+ | </note> | ||
+ | |||
+ | <code user> | ||
+ | cd Essai-text-processing/ | ||
+ | # puis: | ||
+ | split -l 1 ~/Essai-text-processing/liste-fruits | ||
+ | # puis: | ||
+ | ls x* | ||
+ | # Retour: | ||
+ | xaa xab xac | ||
+ | # puis: | ||
+ | cat x* | ||
+ | # Retour : | ||
+ | 1 fraise | ||
+ | 2 abricot | ||
+ | 3 pomme | ||
+ | </code> | ||
+ | |||
+ | |||
=====La commande nl ===== | =====La commande nl ===== | ||
+ | Permet de numéroter l'affichage d'un fichier. | ||
+ | |||
+ | ===Syntaxe === | ||
+ | |||
+ | nl [options] [fichier...] | ||
+ | |||
+ | ===Préparation === | ||
+ | * copie du fichier ~/.bashrc et visualisation : | ||
+ | |||
+ | <code user> | ||
+ | cat ~/.bashrc >> ~/Essai-text-processing/bashrc-bis | ||
+ | </code> | ||
+ | * comparons avec l'affichage de less | ||
+ | <code user> | ||
+ | less ~/Essai-text-processing/bashrc-bis | ||
+ | </code> | ||
+ | Extrait du retour : | ||
+ | <code user> | ||
+ | # ~/.bashrc: executed by bash(1) for non-login shells. | ||
+ | # see /usr/share/doc/bash/examples/startup-files (in the package bash-doc) | ||
+ | # for examples | ||
+ | |||
+ | # If not running interactively, don't do anything | ||
+ | case $- in | ||
+ | *i*) ;; | ||
+ | *) return;; | ||
+ | esac | ||
+ | [...] | ||
+ | ===Affichage numéroté === | ||
+ | <code> | ||
+ | nl ~/Essai-text-processing/bashrc-bis | ||
+ | </code user> | ||
+ | Extrait du retour : | ||
+ | <code> | ||
+ | 1 # ~/.bashrc: executed by bash(1) for non-login shells. | ||
+ | 2 # see /usr/share/doc/bash/examples/startup-files (in the package bash-doc) | ||
+ | 3 # for examples | ||
+ | |||
+ | 4 # If not running interactively, don't do anything | ||
+ | 5 case $- in | ||
+ | 6 *i*) ;; | ||
+ | 7 *) return;; | ||
+ | 8 esac | ||
+ | [...] | ||
+ | </code user> | ||
+ | ===Pour encore plus de lisibilité === | ||
+ | |||
+ | <code user> | ||
+ | fmt -w 65 ~/Essai-text-processing/bashrc-bis | nl ~/Essai-text-processing/bashrc-bis | less | ||
+ | </code> | ||
+ | Extrait du retour : | ||
+ | <code> | ||
+ | 1 # ~/.bashrc: executed by bash(1) for non-login shells. | ||
+ | 2 # see /usr/share/doc/bash/examples/startup-files (in the package bash-doc) | ||
+ | 3 # for examples | ||
+ | |||
+ | 4 # If not running interactively, don't do anything | ||
+ | 5 case $- in | ||
+ | 6 *i*) ;; | ||
+ | 7 *) return;; | ||
+ | 8 esac | ||
+ | |||
+ | [...] | ||
+ | </code> |