Verwendung des readarray-Befehls zum Lesen von 2D-Arrays in Bash

Verwendung Des Readarray Befehls Zum Lesen Von 2d Arrays In Bash



Bash ist eine beliebte Shell-Skriptsprache, die in Linux- und Unix-Betriebssystemen verwendet wird. Es bietet eine Vielzahl von Befehlen und Funktionen, die es einfach machen, sich wiederholende Aufgaben zu automatisieren. Das „readarray“ ist einer der hilfreichsten Befehle in Bash. Mit diesem Befehl können Zeilen aus einer Datei in ein 2D-Array eingelesen werden. In diesem Beitrag gehen wir darauf ein, wie man Zeilen aus einer Datei in ein 2D-Array liest, indem man den „readarray“-Befehl von Bash verwendet.

Verwendung von „readarray“ in Bash

Der Befehl „readarray“ liest Zeilen aus einer Datei oder Standardeingabe und weist sie einem Array zu. Die Syntax für die Verwendung von „readarray“ lautet wie folgt:







Lesearray [ -d TEILEN ] [ -n ANZAHL ] [ - DER URSPRUNG ] [ -s ANZAHL ] [ -T ] Reihe


Die verfügbaren Optionen für den Befehl „readarray“ sind:



'-d TEILEN': Legt das zu verwendende Trennzeichen fest, wenn Zeilen in Array-Elemente aufgeteilt werden, und standardmäßig ist das Trennzeichen ein Zeilenumbruchzeichen.



‘-n ANZAHL’: Gibt die maximale Anzahl von Zeilen an, die in das Array gelesen werden sollen.





'-O URSPRUNG' : Legt den Startindex des Arrays fest.

‘-s ANZAHL’: Gibt die Anzahl der zu überspringenden Zeilen an, bevor in das Array gelesen wird.



'-T': Entfernt das abschließende Zeilenumbruchzeichen aus jeder in das Array eingelesenen Zeile.

Hier ist ein Beispiel für die Verwendung von „readarray“, um Zeilen aus einer Datei in ein 2D-Array zu lesen, und dafür habe ich eine erstellt testdatei.txt dessen Inhalt ist:

1 2 3
4 5 6
7 8 9


Hier ist also das vollständige Bash-Skript, das die Verwendung des Befehls „readarray“ demonstriert:

#!/bin/bash
# Zeilen aus einer Datei in das Array einlesen
Lesearray -T Linien < testdatei.txt
# Deklarieren Sie ein 2D-Array mit 3 Zeilen und 3 Spalten
erklären -A Reihe
# Über die Zeilen iterieren und jede Zeile in Elemente aufteilen
für ich In ' ${!lines[@]} ' ; Tun
IFS = ' ' lesen -R -A Elemente <<< ' ${Zeilen[i]} '
für J In ' ${!Elemente[@]} ' ; Tun
Wenn [ [ -N ' ${Elemente[j]} ' ] ] ; Dann
Reihe [ $i , $j ] = ${Elemente[j]}
Sei
Erledigt
Erledigt
# Drucken Sie das Array
für ( ( ich = 0 ;ich < 3 ;i++ ) ) ; Tun
für ( ( J = 0 ;J < 3 ;j++ ) ) ; Tun
Echo -N ' ${array[$i,$j]} '
Erledigt
Echo
Erledigt


Hier habe ich zuerst ein 2D-Array namens „array“ deklariert und dann mit dem Befehl „readarray“ Zeilen aus einer Datei namens „testfile.txt“ in das Array „lines“ gelesen. Als nächstes durchläuft der Code das Array „lines“ und teilt jede Zeile mit den Befehlen „IFS“ und „read“ in Elemente auf.

Danach speichert es die Elemente im 2D-Array „array“ und verwendet dann den Lesebefehl, um jede Zeile in Elemente aufzuteilen. Nun wird jedes Element dem entsprechenden Element im Array ‚array‘ zugewiesen und schließlich wird der Inhalt des Arrays ‚array‘ mit verschachtelten for-Schleifen ausgegeben.

Abschluss

Der Befehl „readarray“ macht es einfach, große Datenmengen in Bash-Skripten zu manipulieren. Indem Sie den Beispielen in diesem Artikel folgen, können Sie damit beginnen, „readarray“ in Ihren eigenen Bash-Skripten zu verwenden, um Zeilen aus Dateien zu lesen und sie in 2D-Arrays zu verarbeiten.