Fatmawati Achmad Zaenuri / Shutterstock.com
le cat
et tac
Les commandes affichent le contenu des fichiers texte, mais ils ne sont pas à la hauteur. Plongez un peu plus en profondeur et apprenez quelques astuces productives en ligne de commande Linux.
Ce sont deux petites commandes simples, souvent rejetées comme étant juste cela – trop simples pour être d’une utilité réelle. Mais une fois que vous connaissez les différentes façons dont vous pouvez les utiliser, vous verrez qu’ils sont parfaitement capables de faire leur juste part du gros du travail lorsqu’il s’agit de travailler avec des fichiers.
La commande du chat
cat
est utilisé pour examiner le contenu des fichiers texteet pour joindre des parties de fichiers ensemble pour former un fichier plus volumineux.
À un moment donné – à l’époque de la connexion par ligne commutée modem– les fichiers binaires étaient souvent divisés en plusieurs fichiers plus petits pour faciliter le téléchargement. Au lieu de télécharger un fichier volumineux, vous avez retiré chaque fichier plus petit. Si un seul fichier ne parvient pas à se télécharger correctement, vous récupérez simplement ce fichier à nouveau.
Bien sûr, vous aviez alors besoin d’un moyen de reconstituer la collection de fichiers plus petits en un seul fichier binaire de travail. Ce processus s’appelait concaténation. Et c’est là que cat
est venu et d’où il tire son nom.
Les connexions haut débit et fibre ont fait disparaître ce besoin particulier, tout comme les bruits de numérotation stridents, alors que reste-t-il pour cat
faire aujourd’hui? Beaucoup en fait.
Affichage d’un fichier texte
Pour avoir cat
lister le contenu d’un fichier texte dans une fenêtre de terminal, utilisez la commande suivante.
Assurez-vous que le fichier est un fichier texte. Si vous essayez de lister le contenu d’un fichier binaire dans la fenêtre du terminal, les résultats seront imprévisibles. Vous pourriez vous retrouver avec une session de terminal verrouillée ou pire.
cat poem1.txt
Le contenu du fichier poem1.txt est affiché dans la fenêtre du terminal.
Ce n’est que la moitié du célèbre poème. Où est le reste? Il y a un autre fichier ici appelé poem2.txt. Nous pouvons faire cat
lister le contenu de plusieurs fichiers avec une seule commande. Tout ce que nous devons faire est de lister les fichiers dans l’ordre sur la ligne de commande.
cat poem1.txt poem2.txt
Cela semble mieux; nous avons tout le poème maintenant.
Utiliser un chat avec moins
Le poème est tout là, mais il a dépassé la fenêtre trop vite pour lire les premiers versets. Nous pouvons canaliser la sortie de cat
dans less
et faites défiler le texte à notre rythme.
cat poem1.txt poem2.txt | less
Nous pouvons maintenant avancer et reculer dans le texte dans un flux, même s’il est conservé dans deux fichiers texte distincts.
Numérotation des lignes dans un fichier
Nous pouvons avoir le numéro de chat des lignes dans le fichier tel qu’il est affiché. Pour ce faire, nous utilisons le -n
(nombre) option.
cat -n poem1.txt
Les lignes sont numérotées telles qu’elles sont affichées dans la fenêtre du terminal.
Ne numérotez pas les lignes vides
Nous avons réussi à numéroter les lignes par cat
, mais les lignes vides entre les versets sont également comptées. Pour numéroter les lignes de texte mais ignorer les lignes vides, utilisez le -b
(nombre non vide) option.
cat -b poem1.txt
Maintenant, les lignes de texte sont numérotées et les lignes vides sont ignorées.
Ne pas afficher plusieurs lignes vides
S’il y a des sections de lignes vierges consécutives dans un fichier, nous pouvons demander cat
pour ignorer toutes les lignes vides sauf une. Regardez ce fichier.
La prochaine commande provoquera cat
pour afficher une seule ligne vierge de chaque groupe de lignes vierges. L’option dont nous avons besoin pour y parvenir est la -s
(squeeze-blank) option.
cat -s poem1.txt
Cela n’affecte en aucune façon le contenu du fichier; ça change juste la façon cat
affiche le fichier.
Afficher les onglets
Si vous voulez savoir si les espaces sont causés par des espaces ou des tabulations, vous pouvez le découvrir en utilisant le -T
(afficher les onglets) option.
cat -T poem1.txt
Les onglets sont représentés par les caractères «^ I».
Affichage des extrémités des lignes
Vous pouvez vérifier les espaces blancs de fin en utilisant le -E
(show-ends) option.
cat -E poem1.txt
Les extrémités des lignes sont représentées par le caractère «$».
Concaténation de fichiers
Cela n’a pas de sens d’avoir un poème enregistré dans deux fichiers, avec une moitié dans chacun. Joignons-les ensemble et créons un nouveau fichier avec le poème entier.
cat poem1.txt poem2.txt > jabberwocky.txt
utilisons cat
pour vérifier notre nouveau fichier:
cat jabberwocky.txt
Notre nouveau fichier contient le contenu des deux autres fichiers.
Ajout de texte à un fichier existant
C’est mieux, mais en fait, ce n’est pas tout le poème. Le dernier couplet manque. Le dernier couplet de Jabberwocky est le même que le premier couplet.
Si nous avons le premier couplet dans un fichier, nous pouvons l’ajouter au bas du fichier jabberwocky.txt, et nous aurons le poème complet.
Dans cette prochaine commande, nous devons utiliser >>
, pas seulement >
. Si nous utilisons un seul >
nous allons jabberwocky.txt. Nous ne voulons pas faire ça. Nous voulons envoyer un SMS au fond de celui-ci.
cat first_verse.txt >> jabberwocky.txt
Vérifions le contenu du fichier jabberwocky.txt:
cat jabberwocky.txt
Et enfin, toutes les parties du poème sont réunies.
Redirection de stdin
Vous pouvez rediriger l’entrée du clavier dans un fichier en utilisant cat
. Tout ce que vous tapez est redirigé dans le fichier jusqu’à ce que vous appuyiez sur Ctrl + D. Notez que nous utilisons un seul >
parce que nous voulons créer le fichier (ou l’écraser, s’il existe).
cat > my_poem.txt
Nous pouvons commencer à taper dès que nous émettons la commande. Nous appuyons sur Ctrl + D lorsque nous avons terminé. Nous pouvons ensuite vérifier le contenu du nouveau fichier avec:
cat my-poem.txt
Ce son comme une turbine lointaine est probablement Lewis Carroll qui tourne dans sa tombe à grande vitesse.
La commande tac
tac
est similaire à cat
, mais il répertorie le contenu des fichiers dans le sens inverse.
Voyons ça:
tac my_poem.txt
Et le fichier est répertorié dans la fenêtre du terminal dans l’ordre inverse. Dans ce cas, il n’a aucun effet sur ses mérites littéraires.
Utilisation de tac avec stdin
Utilisant tac
sans nom de fichier le fera fonctionner sur l’entrée du clavier. Appuyer sur Ctrl + D arrêtera la phase d’entrée et tac listera dans l’ordre inverse tout ce que vous avez tapé.
tac
Lorsque Ctrl + D est frappé, l’entrée est inversée et répertoriée dans la fenêtre du terminal.
Utilisation de tac avec des fichiers journaux
Outre les astuces de salon de faible qualité, peut tac
faire quelque chose d’utile? Oui il peut. De nombreux fichiers journaux ajoutent leurs dernières entrées au bas du fichier. Utilisant tac
(et, contre-intuitivement, head
), nous pouvons afficher la dernière entrée dans la fenêtre du terminal.
Nous utilisons tac
pour lister le fichier syslog à l’envers et le diriger vers head
. En disant head
pour n’imprimer que la première ligne qu’il reçoit (qui grâce à tac
est la dernière ligne du fichier), nous voyons la dernière entrée dans le fichier syslog.
tac /var/log/syslog | head -1
head
imprime la dernière entrée du fichier syslog, puis quitte.
Noter que head
n’imprime qu’une seule ligne – comme nous l’avons demandé – mais la ligne est si longue qu’elle s’enroule deux fois. C’est pourquoi cela ressemble à trois lignes de sortie dans la fenêtre du terminal.
Utilisation de tac avec des enregistrements de texte
Le dernier truc tac
a dans sa manche est une beauté.
D’habitude, tac
fonctionne sur les fichiers texte en les parcourant ligne par ligne, de bas en haut. Une ligne est une séquence de caractères terminée par un caractère de nouvelle ligne. Mais on peut dire tac
pour travailler avec d’autres délimiteurs. Cela nous permet de traiter des «morceaux» de données dans le fichier texte comme des enregistrements de données.
Disons que nous avons un fichier journal d’un programme que nous devons examiner ou analyser. Jetons un coup d’œil à son format avec less
.
less logfile.dat
Comme nous pouvons le voir, il existe un format répétitif dans le fichier. Il y a des séquences de trois lignes de hexadécimal valeurs. Chaque ensemble de trois lignes hexadécimales a une ligne d’étiquette qui commence «= SEQ», suivie d’une séquence de chiffres.
Si nous faisons défiler vers le bas du fichier, nous pouvons voir qu’il y a beaucoup de ces enregistrements. Le dernier porte le numéro 865.
Supposons que, pour une raison quelconque, nous devons travailler dans ce fichier dans l’ordre inverse, enregistrement de données par enregistrement de données. L’ordre des lignes des trois lignes hexadécimales de chaque enregistrement de données doit être conservé.
Nous noterons que les trois dernières lignes du fichier commencent par les valeurs hexadécimales 93, E7 et B8, dans cet ordre.
Utilisons tac
pour inverser le fichier. C’est un fichier très long, nous allons donc le diriger vers less
.
tac logfile.dat | less
Cela renverse le fichier, mais ce n’est pas le résultat que nous voulons. Nous voulons que le fichier soit inversé, mais les lignes de chaque enregistrement de données doivent être dans leur ordre d’origine.
Nous avons noté plus tôt que les trois dernières lignes du fichier commencent par les valeurs hexadécimales 93, E7 et B8, dans cet ordre. L’ordre de ces lignes a été inversé. De plus, les lignes «= SEQ» sont désormais chaque ensemble de trois lignes hexadécimales.
tac
à la rescousse.
tac -b -r -s ^=SEQ.+[0-9]+*$ logfile.dat | less
Décomposons cela.
le -s
(séparateur) option informe tac
ce que nous voulons utiliser comme délimiteur entre nos enregistrements. Il raconte tac
de ne pas utiliser son caractère de nouvelle ligne habituel, mais d’utiliser notre séparateur à la place.
le -r
(regex) option indique tac
pour traiter la chaîne de séparation comme un expression régulière.
le -b
(avant) les causes de l’option tac
pour lister le séparateur de chaque enregistrement au lieu de le suivre (qui est la position habituelle de son séparateur par défaut, le caractère de nouvelle ligne).
le -s
(séparateur) chaîne ^=SEQ.+[0-9]+*$
est déchiffré comme suit:
le ^
le caractère représente le début de la ligne. Ceci est suivi de =SEQ.+[0-9]+*$
. Cela instruit tac
pour rechercher chaque occurrence de «= SEQ». au début d’une ligne, suivie de toute séquence de chiffres (indiquée par [0-9]
), et suivi de tout autre jeu de caractères (indiqué par *$
).
Nous insufflons le tout dans less
, comme d’habitude.
Notre fichier est maintenant présenté dans l’ordre inverse avec chaque ligne d’étiquette «= SEQ» répertoriant ses trois lignes de données hexadécimales. Les trois lignes de valeurs hexadécimales sont dans leur ordre dans chaque enregistrement de données.
Nous pouvons vérifier cela simplement. La première valeur des trois premières lignes hexadécimales (qui étaient les trois dernières lignes avant l’inversion du fichier) correspond aux valeurs que nous avons enregistrées précédemment: 93, E7 et B8, dans cet ordre.
C’est tout un truc pour une fenêtre de terminal à une seule ligne.
Tout a un but
Dans le monde Linux, même les commandes et les utilitaires apparemment les plus simples peuvent avoir des propriétés surprenantes et puissantes.
La philosophie de conception des utilitaires simples qui font bien une chose, et qui interfonctionnent facilement avec d’autres utilitaires, a donné lieu à d’étranges petites commandes, telles que tac
. À première vue, cela semble être un peu bizarre. Mais lorsque vous regardez sous la surface, il existe un pouvoir inattendu que vous pouvez exploiter à votre avantage.
Ou, comme le dit une autre philosophie, « Ne méprisez pas le serpent pour n’avoir pas de cornes, car qui dit qu’il ne deviendra pas un dragon? »