Portál AbcLinuxu, 20. července 2025 16:51


Dotaz: shell while done

petka avatar 4.2.2009 13:57 petka | skóre: 25 | blog: heydax | Klasterec N/O
shell while done
Přečteno: 336×
Odpovědět | Admin

mesic den cas ip

mesic den cas ip

mesic den cas ip

mesic den cas ip

Potrebuju prevest text.log soubor do mysql databaze a z kazdeho radku vytahuju mesic den cas ip , problem je v tom ze nevim jak  prevest postupne vsechny radky do mysql tabulky

mesic=`cat text.log | awk '{print $1}'`
den=`cat textlog | awk '{print $2}'`
cas=`cat text.log | awk '{print $3}'`
ipadresa=`cat text.log | awk '{print $4}'`



mysql -N -D databaze  -u user -pheslo -e "INSERT INTO tabulka (  mesic , den , cas , ipadresa ) VALUES ('$mesic','$den','$cas','$ipadresa')" databaze

jen vim ze by bylo dobre je zpracovat v cyklech ?


 

Ubuntu server - Asus E35M1​-M ​- AMD Hudson M1 , 2x Technisat Skystar2 , 2x 1GB Lan , WiFi mod AP ,vdr,mysql,apache2...
Nástroje: Začni sledovat (1) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

4.2.2009 14:19 tyctor
Rozbalit Rozbalit vše Re: shell while done
Odpovědět | | Sbalit | Link | Blokovat | Admin

nejako takto:

mysql -N -D databaze  -u user -pheslo < `awk '{printf("INSERT INTO tabulka (mesic, den, cas, ipadresa) VALUES ('"'"%s"'"', '"'"%s"'"', '"'"%s"'"', '"'"%s"'"')\n", $1, $2, $3, $4)}' text.log`
4.2.2009 14:34 marek
Rozbalit Rozbalit vše Re: shell while done
Odpovědět | | Sbalit | Link | Blokovat | Admin

dobry den

Urcite jde napsat:

awk '// {print "mysql -N -D databaze  -u user -pheslo -e \"INSERT INTO tabulka (  mesic , den , cas , ipadresa ) VALUES (\x27" $1 "\x27,\x27" $2 "\x27,\x27" $3 "\x27,\x27" $4 "\x27)\" databaze"}'  < text.log | sh

Tohle bude jakztakz fungovat, pokud tam nebude moc radku. Jinak je lepsi pouzit  konstrukci  LOAD DATA INFILE.

 

 

marek

4.2.2009 14:43 marek
Rozbalit Rozbalit vše Re: shell while done

anebo o neco elegantneji (nemam nikde mysql - nevim, zda se mu nemusi rict, at cte z stdin):

awk '// {print "INSERT INTO tabulka (  mesic , den , cas , ipadresa ) VALUES (\x27" $1 "\x27,\x27" $2 "\x27,\x27" $3 "\x27,\x27" $4 "\x27);" ' < text.log | mysql -N -D databaze  -u user -pheslo databaze

marek

petka avatar 4.2.2009 15:42 petka | skóre: 25 | blog: heydax | Klasterec N/O
Rozbalit Rozbalit vše Re: shell while done

funguje perfektne jen jsem z toho trochu rozpacity ze pouzivam neco aniz bych vedel jak to funguje  , stacilo by me jen trosku nakopnout at v tom moc nelitam , jeste jednou dekuju

Ubuntu server - Asus E35M1​-M ​- AMD Hudson M1 , 2x Technisat Skystar2 , 2x 1GB Lan , WiFi mod AP ,vdr,mysql,apache2...
4.2.2009 17:17 marek
Rozbalit Rozbalit vše Re: shell while done

Dobry den.

Predpokladam ze rozumite vasemu zapisu

cat text.log | awk '{print $1}'

to jde elegantneji prepsat jako

awk '{print $1}' < text.log

tim se odstrani zbytecne volani cat.

Pokud pustite

awk '// {print "mysql -N -D databaze  -u user -pheslo -e \"INSERT INTO tabulka (  mesic , den , cas , ipadresa ) VALUES (\x27" $1 "\x27,\x27" $2 "\x27,\x27" $3 "\x27,\x27" $4 "\x27)\" databaze"}'  < text.log

vypise Vam to akorat preparsovany text (uplne stejne jako ten Vas prikaz), ktery  je vlastne  to, co byste psal na klavesnici, kdybyste to tam rucne cpal.

Takze se to akorat posle rourou na stdin shellu. Neni to ale idealni reseni, protoze se pro kazdy radek znovu vola mysql.

Daleko lepsi je mysql pustit prave jednou a na stdin mu poslat vsechny radky.

takze, kdyz pustite

awk '// {print "INSERT INTO tabulka (  mesic , den , cas , ipadresa ) VALUES (\x27" $1 "\x27,\x27" $2 "\x27,\x27" $3 "\x27,\x27" $4 "\x27);" ' < text.log

vypise Vam to akorat preparsovany text, ktery  je vlastne  to, co byste psal na klavesnici, po spusteni mysql v interaktivnim modu.

To \x27 je zapis uvozovek pro awk.

 

marek

 

 

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.