explode
Die Verarbeitung und Analyse von Datensätzen auf Lokal- bzw. Exemplarebene ist mitunter nur unzureichend möglich, da Filterausdrücke die Grenzen von untergeordneten Ebenen nicht respektiert. Abhilfe kann das explode
-Kommando schaffen, das einen Datensatz in einzelne Lokal- bzw. Exemplardatensätze aufteilen kann. Dabei werden alle Felder der übergeordneten Ebenen mit in die Datensätze übernommen.
Das Aufteilen der Datensätze erfolgt durch die Angabe der Ebene (level) an der der Datensatz geteilt werden soll. Es können folgende Werte ausgewählt werden:
main
(Aufteilen auf Ebene der Titeldaten)local
(Aufteilen auf Ebene der Lokaldaten)copy
(Aufteilen auf Ebene der Exemplardaten)
Soll ein Datensatz in alle Lokaldatensätze aufgeteilt werden, muss die Ebene local
ausgewählt werden. Die neu erstellten Datensätze enthalten alle Titeldaten (Felder der Ebene main), den Identifikator des Lokaldatensatzes (Feld 101@.a
) sowie alle Exemplare, die diesem Lokaldatensatz zugeordnet werden.
Wird darüber hinaus für jedes Exemplar ein eigenständiger Datensatz benötigt, muss die Ebene copy
angegeben werden. Jeder erzeugte Datensatz enthält die Titeldaten (Felder der Ebene main), den Identifikator des Lokaldatensatzes (Feld 101@.a
) und nur die Felder, die zum jeweiligen Exemplar gehören.
Schließlich kann ein Datensatz auch auf Ebene der Titeldaten (main
) aufgeteilt werden. Diese Auswahl verändert nichts am Datensatz und gibt den vollständigen Datensatz mit allen Feldern aus.
Als Beispiel soll folgender (reduzierter) Datensatz dienen:
$ pica print COPY.dat.gz
003@ $0 123456789
002@ $0 Abvz
101@ $a 1
203@/01 $0 0123456789
203@/02 $0 1234567890
101@ $a 2
203@/01 $0 345678901
Dieser Datensatz lässt sich in zwei Datensätze auf Ebene der Lokaldaten aufteilen:
$ pica explode -s local COPY.dat.gz -o local.dat
$ pica print local.dat
003@ $0 123456789
002@ $0 Abvz
101@ $a 1
203@/01 $0 0123456789
203@/02 $0 1234567890
003@ $0 123456789
002@ $0 Abvz
101@ $a 2
203@/01 $0 345678901
Soll jedes Exemplar ein eigenständiger Datensatz werden, wird dies durch Angabe von copy
erzielt:
$ pica explode -s copy COPY.dat.gz -o copy.dat
$ pica print copy.dat
003@ $0 123456789
002@ $0 Abvz
101@ $a 1
203@/01 $0 0123456789
003@ $0 123456789
002@ $0 Abvz
101@ $a 1
203@/02 $0 1234567890
003@ $0 123456789
002@ $0 Abvz
101@ $a 2
203@/01 $0 345678901
Optionen
-s
,--skip-invalid
- Überspringt jene Zeilen aus der Eingabe, die nicht dekodiert werden konnten.
-i
,--ignore-case
- Groß- und Kleinschreibung wird bei Vergleichen ignoriert.
--strsim-threshold <value>
-
Festlegen des Schwellenwerts beim Ähnlichkeitsvergleich von Zeichenketten mittels
=*
.
-k <expr>
, --keep <expr>
Es werden nur die Felder eines Datensatzes beibehalten, die in der Liste aufgeführt werden.
-d
,--discard
- Es werden die Felder eines Datensatzes verworfen, die in der Liste aufgeführt werden.
-l <n>
,--limit
<n>
-
Eingrenzung der Ausgabe auf die ersten
<n>
(gültigen) Datensätze. --where <filter>
- Angabe eines Filters, der auf die erzeugten Datensätze angewandt wird.
--and <expr>
-
Hinzufügen eines zusätzlichen Filters mittels der booleschen
&&
-Verknüpfung. Der ursprüngliche Filterausdruck<filter>
wird zum Ausdruck<filter> && <expr>
. --or <expr>
-
Hinzufügen eines zusätzlichen Filters mittels der booleschen
||
-Verknüpfung. Der ursprüngliche Filterausdruck<filter>
wird zum Ausdruck<filter> || <expr>
. --not <expr>
-
Hinzufügen eines zusätzlichen Filters. Der ursprüngliche Filterausdruck
<filter>
wird zum Ausdruck<filter> && !(<expr>)
. -g
,--gzip
- Komprimieren der Ausgabe im Gzip-Format.
-p
,--progress
-
Anzeige des Fortschritts, der die Anzahl der eingelesenen gültigen sowie invaliden Datensätze anzeigt. Das Aktivieren der Option erfordert das Schreiben der Datensätze in eine Datei mittels
-o
bzw.--output
. -o <filename>
,--output <filename>
-
Angabe, in welche Datei die Ausgabe geschrieben werden soll. Standardmäßig wird die Ausgabe in die Standardausgabe
stdout
geschrieben. Endet der Dateiname mit dem Suffix.gz
, wird die Ausgabe automatisch im Gzip-Format komprimiert.
Beispiele
Eingrenzen der Datensätze
Ist nur eine Teilmenge der erzeugten Datensätze von Interesse, lässt sich die Ergebnismenge durch Hinzufügen eines Filterausdrucks eingrenzen.
Werden bspw. nur die Exemplare mit dem Identifikator 101@.a == "1"
benötigt, kann die Eingrenzung durch Angabe der --where
-Option eingegrenzt werden:
$ pica explode -s copy --where '101@.a == "1"' COPY.dat.gz -o copy.dat
$ pica print copy.dat
003@ $0 123456789
002@ $0 Abvz
101@ $a 1
203@/01 $0 0123456789
003@ $0 123456789
002@ $0 Abvz
101@ $a 1
203@/02 $0 1234567890