abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
eParkomat, startup z ČR, postoupil mezi finalisty evropského akcelerátoru ChallengeUp!
Robot na pivo mu otevřel dveře k opravdovému byznysu
Internet věcí: Propojený svět? Už se to blíží...
dnes 11:44 | Zajímavý projekt

Na Indiegogo byla spuštěna kampaň na podporu herní mini konzole a multimediálního centra RetroEngine Sigma od Doyodo. Předobjednat ji lze již od 49 dolarů. Požadovaná částka 20 000 dolarů byla překonána již 6 krát. Majitelé mini konzole si budou moci zahrát hry pro Atari VCS 2600, Sega Genesis nebo NES. Předinstalováno bude multimediální centrum Kodi.

Ladislav Hagara | Komentářů: 0
dnes 00:10 | Nová verze

Byla vydána verze 4.7 redakčního systému WordPress. Kódové označením Vaughan bylo vybráno na počest americké jazzové zpěvačky Sarah "Sassy" Vaughan. Z novinek lze zmínit například novou výchozí šablonu Twenty Seventeen, náhledy pdf souborů nebo WordPress REST API.

Ladislav Hagara | Komentářů: 0
včera 12:00 | Zajímavý projekt

Projekt Termbox umožňuje vyzkoušet si linuxové distribuce Ubuntu, Debian, Fedora, CentOS a Arch Linux ve webovém prohlížeči. Řešení je postaveno na projektu HyperContainer. Podrobnosti v často kladených dotazech (FAQ). Zdrojové kódy jsou k dispozici na GitHubu [reddit].

Ladislav Hagara | Komentářů: 14
včera 11:00 | Bezpečnostní upozornění

Byly zveřejněny informace o bezpečnostní chybě CVE-2016-8655 v Linuxu zneužitelné k lokální eskalaci práv. Chyba se dostala do linuxového jádra v srpnu 2011. V upstreamu byla opravena minulý týden [Hacker News].

Ladislav Hagara | Komentářů: 1
5.12. 22:00 | Komunita

Přibližně před měsícem bylo oznámeno, že linuxová distribuce SUSE Linux Enterprise Server (SLES) běží nově také Raspberry Pi 3 (dokumentace). Obraz verze 12 SP2 pro Raspberry Pi 3 je ke stažení zdarma. Pro registrované jsou po dobu jednoho roku zdarma také aktualizace. Dnes bylo oznámeno, že pro Raspberry Pi 3 je k dispozici také nové openSUSE Leap 42.2 (zprávička). K dispozici je hned několik obrazů.

Ladislav Hagara | Komentářů: 6
5.12. 06:00 | Zajímavý software

OMG! Ubuntu! představuje emulátor terminálu Hyper (GitHub) postavený na webových technologiích (HTML, CSS a JavaScript). V diskusi k článku je zmíněn podobný emulátor terminálu Black Screen. Hyper i Black Screen používají framework Electron, stejně jako editor Atom nebo vývojové prostředí Visual Studio Code.

Ladislav Hagara | Komentářů: 50
5.12. 06:00 | Zajímavý článek

I letos vychází řada ajťáckých adventních kalendářů. QEMU Advent Calendar 2016 přináší každý den nový obraz disku pro QEMU. Programátoři se mohou potrápit při řešení úloh z kalendáře Advent of Code 2016. Kalendáře Perl Advent Calendar 2016 a Perl 6 Advent Calendar přinášejí každý den zajímavé informace o programovacím jazyce Perl. Stranou nezůstává ani programovací jazyk Go.

Ladislav Hagara | Komentářů: 10
3.12. 16:24 | Nová verze

Byla vydána Mageia 5.1. Jedná se o první opravné vydání verze 5, jež vyšla v červnu loňského roku (zprávička). Uživatelům verze 5 nepřináší opravné vydání nic nového, samozřejmě pokud pravidelně aktualizují. Vydání obsahuje všechny aktualizace za posledního téměř půldruhého roku. Mageia 5.1 obsahuje LibreOffice 4.4.7, Linux 4.4.32, KDE4 4.14.5 nebo GNOME 3.14.3.

Ladislav Hagara | Komentářů: 17
3.12. 13:42 | Pozvánky

V Praze probíhá konference Internet a Technologie 16.2, volné pokračování jarní konference sdružení CZ.NIC. Konferenci lze sledovat online na YouTube. K dispozici je také archiv předchozích konferencí.

Ladislav Hagara | Komentářů: 0
2.12. 22:44 | Komunita

Joinup informuje, že Mnichov používá open source groupware Kolab. V srpnu byl dokončen dvouletý přechod na toto řešení. V provozu je asi 60 000 poštovních schránek. Nejenom Kolabu se věnoval Georg Greve ve své přednášce Open Source: the future for the European institutions (SlideShare) na konferenci DIGITEC 2016, jež proběhla v úterý 29. listopadu v Bruselu. Videozáznam přednášek z hlavního sálu je ke zhlédnutí na Livestreamu.

Ladislav Hagara | Komentářů: 26
Kolik máte dat ve svém domovském adresáři na svém primárním osobním počítači?
 (32%)
 (24%)
 (29%)
 (7%)
 (5%)
 (3%)
Celkem 779 hlasů
 Komentářů: 50, poslední 29.11. 15:50
Rozcestník
Reklama

Dotaz: jak se otestuje, jestli proměná existuje v poli

26.10.2009 21:21 Jcas | skóre: 19 | blog: linux v rukou ...
jak se otestuje, jestli proměná existuje v poli
Přečteno: 396×
Mám definováno pole s několika prvky. Využiji vstupu (read) a jestli proměná exituje v poli, tak chcu nadále pracovat poze s touto proměnou (s tímto jedním prvkem z pole) a pokud neexistuje, potřebuji pro read poskytnout druhy pokus (preklep). děkuji

Odpovědi

26.10.2009 21:31 FooBar
Rozbalit Rozbalit vše Re: jak se otestuje, jestli proměná existuje v poli
Mozna by pomohly detaily, jako treba o jaky jazyk se jedna...
26.10.2009 21:34 Jcas | skóre: 19 | blog: linux v rukou ...
Rozbalit Rozbalit vše Re: jak se otestuje, jestli proměná existuje v poli
omlouvám se bash
26.10.2009 21:32 Jcas | skóre: 19 | blog: linux v rukou ...
Rozbalit Rozbalit vše Re: jak se otestuje, jestli proměná existuje v poli
napadlo mě
read y
${pole[$y]}
ale v okamziku preklepu jsem na mrtvem bode.
Víťa Šmíd avatar 26.10.2009 21:59 Víťa Šmíd | skóre: 41 | blog: vituv_blog | Praha
Rozbalit Rozbalit vše Re: jak se otestuje, jestli proměná existuje v poli
Co třeba takhle? Pole to přímo není, ale bash AFAIK stejně nemá nativní funkci pro vyhledávání v poli, takže toto by mohlo být i efektivnější.
check() {
	what=$1
	shift
	for i in $@; do
		[ "$what" = "$i" ] && return 0
	done
	return 1
}

while true; do
	read x
	check $x alpha beta gamma && break
done

echo $x
When Chuck Norris plays Monopoly, it affects the actual world economy. | Matematika pro normální lidi
27.10.2009 08:10 Jcas | skóre: 19 | blog: linux v rukou ...
Rozbalit Rozbalit vše Re: jak se otestuje, jestli proměná existuje v poli
Pěkné děkuji. A ještě, protože jsu laik bych poprosil vysvětlení (jestli to chápu správně). Vím že tohle nemáte rádi "neotravuj a nastuduj si to", ale hned jak došla tato odpověď, tak jsem studoval, co se vlastne děje. Takže jestli jsem to pochopil dobře.
while true; do   
    read x
    check $x alpha beta gamma && break  
done
Je-li splněna podmínka true, provede se cyklus. Protože následně volám funkci, která vrací true, nebo false, cyklus bud probehne, nebo ne. Volám funkci check a $x, kterou zadal uživatel odesílám jako první poziční parametr. alpha beta gamma odesílám jako další poziční parametry.

Takže takhle může přece odeslat přímo to pole a zpracuje se to stejně???
check $x ${pole[*]}
funkce check()

definuju promenou what=$1, což znamená, že ji přiřadím první poziční prametr, tedy naše $x, který zadal uživatel.

shift zajistí posun poz. par.

a následně v cyklu for přiřadím prom. i všechny poziční parametry pomocí $@.
[ "what" = "i" ] && return 0
jestli se what = i, tedy jestli naše zadané $x se najde ve výpisu poz. par. ($@), pak funkce vrátí nepravdu a protože podmínka cyklu while nebyla splněna, cyklus neproběhne a script pokračuje dalším příkazem.

Zde mám nejasnost s shift. Neměl by být umístěn později? Když posunu poz. param., tak $1 zmizí a na její místo se posune $2. To by přece znamenalo, že už potom nebude figurovat v $@ a tedy se nesplní podmínka [ "what" = "i" ] No ono to funguje, takže tohle nechápu. Mě připadá logické umístit shift na konec funkce.

27.10.2009 13:01 Jirka P
Rozbalit Rozbalit vše Re: jak se otestuje, jestli proměná existuje v poli
shift je tam dobře. Po tom, co jste si uložil to, co hledáte, do $what, se ho tím shiftem zbavíte, a v $@ vám zbyde jen to prohledávané pole. Naopak, shift na konci funkce je k ničemu (parametry tam stejně přestávají existovat).
Víťa Šmíd avatar 27.10.2009 13:10 Víťa Šmíd | skóre: 41 | blog: vituv_blog | Praha
Rozbalit Rozbalit vše Re: jak se otestuje, jestli proměná existuje v poli
Je to trošku jinak.

Funkce check očekává jako 1. parametr to zadané x (jehlu) a na všech dalších pozicích seznam povolených hodnot (kupku sena). Když si do what přiřadím $1 a provedu shift, v seznamu parametrů mi zbudou jen ty povolené hodnoty. Pokud je při provádění cyklu splněna podmínka [ "$what" = "$i" ], znamená to, že jehla se v kupce sena našla a funkce tím pádem vrátí pravdu (nulová návratová hodnota znamená úspěch). Pokud cyklus proběhne do konce a jehla se nenajde, funkce vrátí 1, což značí neúspěch. check bych nazval funkcí s negativním očekáváním.

Cyklus while true sám o sobě nikdy neskončí – true bude pravda až do konce světa :-). check $x alpha beta gamma && break znamená, že v případě úspěchu funkce check() se nekonečný cyklus přeruší a program pokračuje dál. break je jedna z možností, jak přerušit nekonečný cyklus. Jestli z nějakého jazyka znáš cyklus s logikou do – while, tak tohle je obezlička pro jazyky, které mají jen while – do:
while (true) {
  delej_neco();
  if (!podminka) {
    break;
  }
}
Volání pomocí check $x ${pole[*]} je samozřejmě v pořádku.
When Chuck Norris plays Monopoly, it affects the actual world economy. | Matematika pro normální lidi
27.10.2009 17:20 Ash | skóre: 53
Rozbalit Rozbalit vše Re: jak se otestuje, jestli proměná existuje v poli
Volání pomocí check $x ${pole[*]} je samozřejmě v pořádku.

No, přijde na to... Dost doporučuji používat ${pole[@]} místo ${pole[*]} popř. $@ místo $* kde to jen jde, poměrně často se vyskytne podmínka že hodnoty v poli mohou obsahovat mezery.
27.10.2009 17:41 Ash | skóre: 53
Rozbalit Rozbalit vše Re: jak se otestuje, jestli proměná existuje v poli
I když při standardním nastavení IFS (mezera atd.) to v tomto případě vyjde nastejno, to je fakt.
27.10.2009 18:19 Jirka P
Rozbalit Rozbalit vše Re: jak se otestuje, jestli proměná existuje v poli
Právě že ono to nevyjde nastejno (resp. vyjde to nastejno vždy, nezávisle na IFS). Funguje to tak, že některé tokeny (musel bych se podívat, které to přesně jsou) se po nahrazení proměnných ještě rozdělí na pole podle IFS. Tedy

A="ls -a"
$A

spustí ls s parametrem -a. V tomhle případě je jedno, co je tam za proměnnou, důležité je, že její výskyt není v uvozovkách. Když to dáme do uvozovek, žádná expanze na pole se neprovede:

A="ls -a"
"$A"

zahlásí chybu, že program "ls -a" neexistuje. Je ale výjimka: pokud do uvozovek dáte proměnnou $@ nebo ${xxx[@]}, expanze na pole se provede, ale ne podle IFS (mezery apod.), ale tak, aby byly zachovány původní parametry/prvky pole. Příklad (spusťte a sledujte chybové hlášky):

set ls "adresář neexistuje"
$*
"$*"
$@
"$@"

Závěr: když nechcete expanzi, používejte @ místo * a dávejte to do uvozovek.
28.10.2009 09:23 Ash | skóre: 53
Rozbalit Rozbalit vše Re: jak se otestuje, jestli proměná existuje v poli
Hezké příklady a máte pravdu, zapomněl jsem opravit uvozovky i v té funkci in_array, takže mi to nefungovalo... Finálně tedy:
in_array() {
  local i
  needle=$1
  shift 1
  for i in "$@"; do
    [[ "$i" == "$needle" ]] && return 0
  done
  return 1
}

pole[0]=foo
pole[1]=bar
pole[2]="dve slova"

read slovo

in_array $slovo "${pole[@]}" && echo ok
28.10.2009 09:25 Ash | skóre: 53
Rozbalit Rozbalit vše Re: jak se otestuje, jestli proměná existuje v poli
in_array "$slovo" tedy
27.10.2009 08:02 Ash | skóre: 53
Rozbalit Rozbalit vše Re: jak se otestuje, jestli proměná existuje v poli
Google, "in_array bash". Upravená verze zde:
in_array()
{
  local i
  needle=$1
  shift 1
  # array() undefined
  [ -z "$1" ] && return 1
  for i in $@
  do
    [ "$i" == "$needle" ] && return 0
  done
  return 1
}

pole[0]=foo
pole[1]=bar
pole[1]="dve slova"

read slovo

if in_array $slovo ${pole[@]}; then
  echo ok
else
  echo ko
fi
27.10.2009 12:56 Jirka P
Rozbalit Rozbalit vše Re: jak se otestuje, jestli proměná existuje v poli
  # array() undefined
  [ -z "$1" ] && return 1

Tohle je hodně divné. Proč by se v poli, které začíná prázdným řetězcem, nemělo dát nic najít?
27.10.2009 16:44 Ash | skóre: 53
Rozbalit Rozbalit vše Re: jak se otestuje, jestli proměná existuje v poli
jo, autor se patrně sekl, podmínku bych odstranil
27.10.2009 20:09 Jcas | skóre: 19 | blog: linux v rukou ...
Rozbalit Rozbalit vše Re: jak se otestuje, jestli proměná existuje v poli
děkuji mockrát. Myslím, že co se týče této funkce jsem to už pochopil na 100%

Založit nové vláknoNahoru

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

ISSN 1214-1267   www.czech-server.cz
© 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.