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í
×
    včera 05:00 | Nová verze

    Byla vydána beta verze Linux Mintu 22.3 s kódovým jménem Zena. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze, že nástroj Systémová hlášení (System Reports) získal mnoho nových funkcí a byl přejmenován na Informace o systému (System Information). Linux Mint 22.3 bude podporován do roku 2029.

    Ladislav Hagara | Komentářů: 2
    včera 01:55 | Nová verze

    GNU Project Debugger aneb GDB byl vydán ve verzi 17.1. Podrobný přehled novinek v souboru NEWS.

    Ladislav Hagara | Komentářů: 0
    19.12. 17:22 | IT novinky

    Josef Průša oznámil zveřejnění kompletních CAD souborů rámů tiskáren Prusa CORE One a CORE One L. Nejsou vydány pod obecnou veřejnou licenci GNU ani Creative Commons ale pod novou licencí OCL neboli Open Community License. Ta nepovoluje prodávat kompletní tiskárny či remixy založené na těchto zdrojích.

    Ladislav Hagara | Komentářů: 3
    19.12. 17:00 | Komunita

    Nový CEO Mozilla Corporation Anthony Enzor-DeMeo tento týden prohlásil, že by se Firefox měl vyvinout v moderní AI prohlížeč. Po bouřlivých diskusích na redditu ujistil, že v nastavení Firefoxu bude existovat volba pro zakázání všech AI funkcí.

    Ladislav Hagara | Komentářů: 0
    19.12. 10:11 | IT novinky

    V pořadí šestou knihou autora Martina Malého, která vychází v Edici CZ.NIC, správce české národní domény, je titul Kity, bity, neurony. Kniha s podtitulem Moderní technologie pro hobby elektroniku přináší ucelený pohled na svět současných technologií a jejich praktické využití v domácích elektronických projektech. Tento knižní průvodce je ideální pro každého, kdo se chce podívat na současné trendy v oblasti hobby elektroniky, od

    … více »
    Ladislav Hagara | Komentářů: 4
    19.12. 03:11 | Komunita

    Linux Foundation zveřejnila Výroční zprávu za rok 2025 (pdf). Příjmy Linux Foundation byly 311 miliónů dolarů. Výdaje 285 miliónů dolarů. Na podporu linuxového jádra (Linux Kernel Project) šlo 8,4 miliónu dolarů. Linux Foundation podporuje téměř 1 500 open source projektů.

    Ladislav Hagara | Komentářů: 0
    19.12. 02:11 | Zajímavý článek

    Jean-Baptiste Mardelle se v příspěvku na blogu rozepsal o novinkám v nejnovější verzi 25.12.0 editoru videa Kdenlive (Wikipedie). Ke stažení také na Flathubu.

    Ladislav Hagara | Komentářů: 0
    19.12. 02:00 | Nová verze

    OpenZFS (Wikipedie), tj. implementace souborového systému ZFS pro Linux a FreeBSD, byl vydán ve verzi 2.4.0.

    Ladislav Hagara | Komentářů: 0
    19.12. 01:00 | IT novinky

    Kriminalisté z NCTEKK společně s českými i zahraničními kolegy objasnili mimořádně rozsáhlou trestnou činnost z oblasti kybernetické kriminality. V rámci operací OCTOPUS a CONNECT ukončili činnost čtyř call center na Ukrajině. V prvním případě se jednalo o podvodné investice, v případě druhém o podvodné telefonáty, při kterých se zločinci vydávali za policisty a pod legendou napadeného bankovního účtu okrádali své oběti o vysoké finanční částky.

    Ladislav Hagara | Komentářů: 8
    18.12. 14:44 | IT novinky

    Na lepší pokrytí mobilním signálem a dostupnější mobilní internet se mohou těšit cestující v Pendolinech, railjetech a InterPanterech Českých drah. Konsorcium firem ČD - Telematika a.s. a Kontron Transportation s.r.o. dokončilo instalaci 5G opakovačů mobilního signálu do jednotek Pendolino a InterPanter. Tento krok navazuje na zavedení této technologie v jednotkách Railjet z letošního jara.

    Ladislav Hagara | Komentářů: 7
    Kdo vám letos nadělí dárek?
     (27%)
     (2%)
     (12%)
     (2%)
     (2%)
     (2%)
     (12%)
     (24%)
     (15%)
    Celkem 41 hlasů
     Komentářů: 14, poslední včera 19:13
    Rozcestník

    Dotaz: PHP funkce

    13.2.2011 23:18 Pepino
    PHP funkce
    Přečteno: 479×
    Dobrý večer, dovolil bych si prosím požádat jako ještě celkem nezkušený s jednou funkcí.

    Mám proměne:
    $prom1 = "neco";
    $prom2_pozice = "1";
    $znak1 = "S";
    $znak2 = "E";
    a potrebuji najit v souboru cast textu, ktery podle promenych rika: budu hledat 1 text "neco" za timto textem najdu první znak S a prvni znak E a mezi temito znaky vyberu text.

    Vůbec nevim jak na to mam jit. Poradil by mi prosím někdo? Googloval jsem cele odpoledne ale nenasel jsem vubec nic. Dekuji za pomoc. Pepa

    Řešení dotazu:


    Odpovědi

    Přemek Vyhnal avatar 14.2.2011 00:01 Přemek Vyhnal | skóre: 24 | blog: Toto není blog! | Dobřichovice
    Rozbalit Rozbalit vše Re: PHP funkce
    Nebylo by lepší použít regulární výraz? Něco jako /neco.*?S(.*?)E/
    NO RAPTORS!
    15.2.2011 19:55 Ben Joyce
    Rozbalit Rozbalit vše Re: PHP funkce
    Příloha:
    Mozna to je trochu neprehledne a nejspise by se nasel lepsi pristup k tomuto problemu, ale toto je muj prvni napad.
    Pokud jsem dobre pochopil problem, chcete vyhledavat od pozice $prom2_pozice text $prom1 a dale vyhledat prvni znak $znak1 a prvni znak $znak2 a ziskat text mezi temito znaky.
    Problem je reseny obecne, takze $prom1 muze byt napriklad i veta, ale znaky jsem zachoval jako znaky.
    Zde je kod:

    function vybrat_z_textu($prom2_pozice, $prom1, $znak1, $znak2, $string)
    {
    // vstupni kontrola
    if (strlen($prom1) < 1)
    $nalez = true;
    else
    $nalez = false;

    if (strlen($string) < 1)
    return;



    // zjisti delku textu
    $prom_lenght = strlen($prom1);
    $string_lenght = strlen($string);

    // prom2_pozice by mela obsahovat cislo v poradi znaku - tedy zacni na
    // patem znaku => $prom2_pozice = 5;
    $i = $prom2_pozice - 1;
    // probiha hledani klicove fraze $prom1 v textu
    while (($nalez != true) || ($string_lenght >= ($i + 1)))
    {
    // pokud prvni znak klic. fraze je shodny se znakem, ktery je na rade
    if ($string[$i] == $prom1[0])
    {
    // zjisti zdali dalsi znaky jsou shodne
    $n = $i + 1;
    for ($j = 1; $j <= ($prom_lenght - 1); ++$j)
    {
    if ($string[$n] != $prom1[$j])
    break;
    else
    $uspech = true;
    ++$n;
    }

    // pokud jsou dalsi znaky shodne, "vrati" pozici po klic. frazi
    if ($uspech)
    {
    $i = $n;
    break;
    }
    }


    ++$i;
    }


    // vyhleda obe pismena
    $pozice_prvniho = 0;
    $pozice_druheho = 0;
    while (($nalez_druheho != true) || ($string_lenght >= ($i + 1)))
    {
    if ($string[$i] == $znak1)
    $pozice_prvniho = $i;

    if ($string[$i] == $znak2)
    {
    $pozice_druheho = $i;
    $nalez_druheho = true;
    }

    ++$i;
    }


    // vybere a vrati text mezi znaky
    return substr($string, $pozice_prvniho + 1,
    ($pozice_druheho - $pozice_prvniho) - 1);
    }


    A zde je doplnek, na kterem muzete kod vyzkouset:

    // vstupni data
    $prom1 = "neco";
    // predpokladam ze je zde pozice, na ktere ma zacit vyhledavat
    $prom2_pozice = 1;
    $znak1 = "S";
    $znak2 = "E";

    // vstupni text
    $string = "Toto je cvicny text. Jde pouze o to, aby zde program nasel
    slovo Neco NECO NeCo neco (zkouska) a potom pismeno S a mezi tim ma byt text - tedy je zde.
    Nyni jiz musi najit pismeno E. A je to.";
    var_dump(vybrat_z_textu($prom2_pozice, $prom1, $znak1, $znak2, $string));

    Cely soubor (samostatne funkcni) naleznete v priloze.
    15.2.2011 23:21 l4m4
    Rozbalit Rozbalit vše Re: PHP funkce
    Lze se pak divit, že má PHP tak hroznou pověst?
    16.2.2011 09:41 Vjetnam
    Rozbalit Rozbalit vše Re: PHP funkce
    To je opravdu krize. Misto 1 radku kodu s regularnim vyrazem takovy bastl...
    16.2.2011 10:37 Ben Joyce
    Rozbalit Rozbalit vše Re: PHP funkce
    Regularni vyrazy by snad vratili pouze true nebo false, ne?
    16.2.2011 10:45 Ben Joyce
    Rozbalit Rozbalit vše Re: PHP funkce
    Beru zpet, podival jsem se do dokumentace - vrati nejspise integer ukazujici na pozici vyskytu. Nenapadlo me to resit pres reg. vyrazy, bylo by to o dost kratsi.
    16.2.2011 12:11 jos
    Rozbalit Rozbalit vše Re: PHP funkce
    podívej se ještě jednou a pořádně

    vrací to počet matchů, samotný matche ti to nacpe (preg_match) do třetího parametru
    16.2.2011 18:41 Ben Joyce
    Rozbalit Rozbalit vše Re: PHP funkce
    Pravda, to by to jeste podstatne zjednodusilo - pomalu do jednoho radku.
    16.2.2011 10:17 novak
    Rozbalit Rozbalit vše Re: PHP funkce
    Ne. Protoze v nem kdejakej bastlir vybastli kdejakej polofunkcni bastl a jeste se sam nazve programatorem.
    Michal Wirth avatar 16.2.2011 18:44 Michal Wirth | skóre: 26
    Rozbalit Rozbalit vše Re: PHP funkce
    no, misto takovy machisticky hlasky byste mohl priste poskytnout nejaky lepsi reseni ... ne kazdy totiz spadl z nebe uceny tak, jako vy
    Důležité se časem stává absurdním, absurdní se časem mění v důležité.
    16.2.2011 21:35 l4m4
    Rozbalit Rozbalit vše Re: PHP funkce
    A to konkrétně proč?

    Řešení už je přece v prvním komentáři, výrazně starším než ten, na který jsem reagoval. Přesný regulární výraz z toho dotazu stejně nezkonstruuji, protože např. nerozumím, jak se vlastně použije ta jednička.
    Michal Wirth avatar 17.2.2011 07:58 Michal Wirth | skóre: 26
    Rozbalit Rozbalit vše Re: PHP funkce
    ja jsem uz psal proc ... pokud jste mel potrebu na neco takoveho reagovat, mohl jste vzit v potaz, ze dotycny je evidentne zacatecnikem a neshazovat ihned jeho reseni

    navic pokud byste nemel po ruce regexpy, tak byste to ve vysledku pravdepodobne resil podobnym "rychlo-bastlem" a asi by vas hned nenapadl nejaky efektivnejsi algoritmus

    ja take uplne nepochopil, co tazatel vlastne chce, ale nevidim nic slusneho na zesmesnovani nekoho, kdo se pokusil dat aspon nejakou "rozumnejsi" odpoved
    Důležité se časem stává absurdním, absurdní se časem mění v důležité.
    17.2.2011 09:25 l4m4
    Rozbalit Rozbalit vše Re: PHP funkce
    Kdyby se příspěvek, na který jsem reagoval, objevil první, a až poté řešení s regexpem, tak bych takto nereagoval. V tomto případě se ovšem dotyčný začátečník mohl poučit, že to jde dělat řádově lépe, a nedávat sem ty špagety. Že to neudělal... no, proto mají PHP a programátoři v něm pověst, jakou mají.
    17.2.2011 13:09 Ben Joyce
    Rozbalit Rozbalit vše Re: PHP funkce
    Ano, mohl bych se poučit, ale dříve jsem pokaždé použil reg. výraz jen v situaci, kdy jsem potřeboval true nebo false - tedy měl jsem zafixovanou návratovou hodnotu preg_match jako bool. Tedy jsem neviděl nějaké řešení. Je ale pravda, že jsem se měl ujistit v dokumentaci.
    Michal Wirth avatar 17.2.2011 13:13 Michal Wirth | skóre: 26
    Rozbalit Rozbalit vše Re: PHP funkce
    ano, to byste priste mel
    Důležité se časem stává absurdním, absurdní se časem mění v důležité.
    Michal Wirth avatar 16.2.2011 18:26 Michal Wirth | skóre: 26
    Rozbalit Rozbalit vše Re: PHP funkce
    na prvni pohled to vypada, ze by to mozna mohlo nejak fungovat, neni to ale ani bezpecne ani jednoduche a ani efektivni reseni, coz je spatne ... nelze totiz na prvni pohled zjistit, co to vlastne dela a zda je to tak spravne ... je lepsi vyuzit prostredku, ktere jsou pro toto urceny a ktere jsou uz lety proverene ... treba zde lze elegantne uplatnit regularni vyrazy ... napr. takto
    /*
     * Najde v ramci textu prvni vyskyt slova "neco" a vrati prvni podretezec,
     * ktery nasleduje za timto nalezem mezi pismeny "S" a "E" (bez ohledu na
     * spravne parovani znaku). Pokud nedojde ke shode, funkce vraci false.
     */
    function foo($text)
    {
    	$matches = array();
    
    	if (preg_match('/neco[^S]*S([^E]*)E/', $text, $matches) > 0)
    		return $matches[1];
    
    	return false;
    }
    Důležité se časem stává absurdním, absurdní se časem mění v důležité.
    16.2.2011 19:06 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: PHP funkce
    Ale nužno podotknouti, že kdyby byly parametrické i další proměnné ze zadání, nebylo by to již tak triviální. A nakonec by se dospělo k podobnému klonu „ručního“ řešení jak zde byl již uvedeno, nebo by se funkce značně rozvinula na ošetření vstupu a generování platného regexp.
    Nad 1. řešením by chtělo „malinko“ zapracovat, ale jinak obě jsou dobrá, ale každé na něco jiného :).
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    Michal Wirth avatar 16.2.2011 19:27 Michal Wirth | skóre: 26
    Rozbalit Rozbalit vše Re: PHP funkce
    ano, muselo by se to jeste dodelat
    Důležité se časem stává absurdním, absurdní se časem mění v důležité.

    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.