Ich verwende Ubuntu 20.04.1
Ich habe Libre Office Calc. mit zwei funktionierenden Spalten.
Ich bearbeite diese beiden Spalten einmal wöchentlich.
A 987654320
B 987654321
C 987654322
D 987654323
E 987654324
F 987654325
G 987654326
Ich muss ein Bash-Skript schreiben, das die Daten aus den beiden obigen Spalten abruft und eine Textdatei wie unten als Beispiel erstellt.
BEGIN:VCARD
VERSION:3.0
FN:$(content of column1, row1)
N:$(content of column1,row1)
TEL;TYPE=cell:$(content of column2, row1)
END:VCARD
BEGIN:VCARD
VERSION:3.0
FN:$(content of column1, row2)
N:$(content of column1,row2)
TEL;TYPE=cell:$(content of column2, row2)
END:VCARD
and so on till it finds the content at last existing row
Antwort1
Wir können das gewünschte Ergebnis mit einem zweistufigen Prozess erzielen:
Wir konvertieren Tabellenkalkulationen indatei.txt(wirklich CSV):
localc --headless --convert-to txt:"Text - txt - csv (StarCalc)" file.ods
verwenden Sie einige AWK-Skripte:
awk -F, '{ print "BEGIN:VCARD" print "VERSION:3.0" print "FN:"$1 print "N:"$1 print "TEL;TYPE=cell:"$2 print "END:VCARD" print "" }' file.txt