Portál AbcLinuxu, 12. května 2024 11:58


Dotaz: bash a skript proměnné

25.5.2016 11:29 Bash
bash a skript proměnné
Přečteno: 646×
Odpovědět | Admin
jakým způsobem zapsat toto ve skriptu:

Login=`awk -F ";" '$9 == $i {print $2}' $Tabulka`; echo $Login;

Přímo v hashi to funguje a ve skritpu ne.
Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

25.5.2016 15:28 Jan
Rozbalit Rozbalit vše Re: bash a skript proměnné
Odpovědět | | Sbalit | Link | Blokovat | Admin
Má skript definovanou proměnnou Tabulka? Pokud ne, tak je potřeba ji vytvořit. Jiný potenciální problém tam nevidím. Co znamená "nefunguje"?
26.5.2016 08:31 Bash
Rozbalit Rozbalit vše Re: bash a skript proměnné
Soubor Tabulka je definovaná. Ale ve skriptu se mě neuloží výsledek příkazu do proměnné Login. Jak jsem psal - přímo v bashi to funguje.
26.5.2016 09:22 Kit | skóre: 45 | Brno
Rozbalit Rozbalit vše Re: bash a skript proměnné
Přímo v Bashi to určitě také nefunguje, protože se např. $9 pokusí expandovat a tím zdemoluje podmínku.
Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
26.5.2016 09:50 Bash
Rozbalit Rozbalit vše Re: bash a skript proměnné

Máte pravdu. Můžete prosím poradit ja se toto dá udělat.

Zjdednodušený skript toho co potřebuji:

#!/bin/bash

Tabulka="Tabulka_kontakty_bez_nadpisu.csv";

for i in `awk -F ";" '{print $9}' $Tabulka`; do echo $i; Soubor=$i'.html';

Jmeno=`awk -F ";" '$9 == $i {print $2}' $Tabulka`;

Funkce=`awk -F ";" '$9 == $i {print $4}' $Tabulka`;

echo $Jmeno;

echo $Funkce; done

26.5.2016 10:12 Kit | skóre: 45 | Brno
Rozbalit Rozbalit vše Re: bash a skript proměnné
#!/bin/bash
Tabulka="Tabulka_kontakty_bez_nadpisu.csv";
awk -F ";" '{printf("Soubor: %s.html\nJméno: %s\nFunkce: %s\n", $9, $2, $4)}' "$Tabulka"
Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
26.5.2016 10:39 Ja
Rozbalit Rozbalit vše Re: bash a skript proměnné
#!/usr/bin/env bash

Tabulka="Tabulka_kontakty_bez_nadpisu.csv";

while read line; do
  Id=$(cut -d ';' -f 9 <<< "$line")
  Soubor="${Id}.html"
  Jmeno=$(cut -d ';' -f 2 <<< "$line")
  Funkce=$(cut -d ';' -f 4 <<< "$line")
  echo "$Jmeno"
  echo "$Funkce"
done < "$Tabulka"
Není to přesně to co je v tom zjednodušeném scriptu, ale mohlo by to k tomu vést... Když nic jiného, tak to aspoň zavírá do uvozovek věci, které by nejspíš v uvozovkách být měly :-).

Pochopitelně to není správné parsování csv, kde se může vyskytnout i 12;"aa;bb";cc.
26.5.2016 11:36 Kit | skóre: 45 | Brno
Rozbalit Rozbalit vše Re: bash a skript proměnné
Tohle považuji za nešťastné řešení - ten cut je tam zcela zbytečný.
#!/usr/bin/env bash
Tabulka="Tabulka_kontakty_bez_nadpisu.csv";
while IFS=";" read n1 Jmeno n3 Funkce n5 n6 n7 n8 Id n1O; do
    Soubor="${Id}.html"
    echo "$Jmeno"
    echo "$Funkce"
done < "$Tabulka"
Ve srovnání s AWK je to výrazně pomalejší. Pro několik set položek to však může vyhovovat.
Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
jose17 avatar 27.5.2016 00:10 jose17 | skóre: 44 | blog: Joseho_blog | Bratislava
Rozbalit Rozbalit vše Re: bash a skript proměnné
na parsovanie csv suboru nie je shell prilis vhodny, nakolko si neporadi s riadkami ako napr. "field1";"field2;my note";"field3" alebo zaznamom rozdelenym na viac riadkov. na tento ucel sa mi zda vhodnejsie pouzit napr. python, ktory nema od shellovej syntaxe az tak daleko.
Ja vim, on vi, ty nano!
27.5.2016 01:03 Kit | skóre: 45 | Brno
Rozbalit Rozbalit vše Re: bash a skript proměnné
Python se na parsování CSV určitě hodí mnohem lépe. Zde uvedené skripty si neporadí ani s uvozovkami.

Osobně na zpracování CSV používám PHP. Možná to není tak dobrý nástroj, ale zpravidla nic lepšího nepotřebuji a mnohem snáze se mi ta data dále zpracovávají.
Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
27.5.2016 09:05 Ja
Rozbalit Rozbalit vše Re: bash a skript proměnné
Python má proti php jednu podstatnou výhodu - zpravidla je všude ve výchozí instalaci.
#!/usr/bin/env python
import csv

tabulka = "Tabulka_kontakty_bez_nadpisu.csv"
for row in csv.reader(open(tabulka, 'r'), delimiter=";"):
  soubor = "%s.html" % row[8]
  jmeno = row[1]
  funkce = row[3]
  print (jmeno)
  print (funkce)
je třeba si dát pozor na to, že pole je indexované od nuly a že odsazení řádku má význam - které příkazy budou opakovány ve smyčce for je dáno mezerami na začátku řádky!

Dokumentace k použití cvs v pythonu je tady, ale myslím, že to ani není třeba zkoumat.
jose17 avatar 29.5.2016 20:25 jose17 | skóre: 44 | blog: Joseho_blog | Bratislava
Rozbalit Rozbalit vše Re: bash a skript proměnné
ak sa chcete pouzitiu vyssieho programovacieho jazyku vyhnut, mozte trebars vyuzit (s urcitymi obmedzeniami) gnu awk: https://www.gnu.org/software/gawk/manual/html_node/Splitting-By-Content.html
Ja vim, on vi, ty nano!
30.5.2016 09:15 Ja
Rozbalit Rozbalit vše Re: bash a skript proměnné
Jen pozor na to, že použití awku dle uvedeného linku si neporadí s uvozovkami uvnitř pole, které se v csv běžně escapují zdvojením - tedy:
12;"Přímá řeč: ""No nazdar!""; řekl Karel.";34
O konci řádku uvnitř uvozovek ani nemluvě.
30.5.2016 11:26 Kit | skóre: 45 | Brno
Rozbalit Rozbalit vše Re: bash a skript proměnné
To je velká škoda, že se AWK na CSV kromě speciálních případů prakticky nedá použít.
Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
Jendа avatar 25.5.2016 19:57 Jendа | skóre: 78 | blog: Jenda | JO70FB
Rozbalit Rozbalit vše Re: bash a skript proměnné
Odpovědět | | Sbalit | Link | Blokovat | Admin
Spusť to s bash -x.
Já to s tou denacifikací Slovenska myslel vážně.
26.5.2016 09:28 Bash
Rozbalit Rozbalit vše Re: bash a skript proměnné
toto nepomohlo
26.5.2016 09:32 GeorgeWH | skóre: 42
Rozbalit Rozbalit vše Re: bash a skript proměnné
miesto slepeho kopirovania a spustania prikazov, co ti tu poradia, by si si mal zistit, co ti vlastne radia. takze man bash a hladat -x.

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.