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í
×

dnes 22:22 | Zajímavý software

Společnosti Haivision a Wowza společně oznámily vznik SRT Alliance a otevření protokolu pro streamování videa SRT. Podrobnosti v FAQ. Zdrojové kódy SRT jsou k dispozici na GitHubu pod open source licencí LGPLv2.1.

Ladislav Hagara | Komentářů: 0
dnes 12:33 | Humor

Byl vydán remake filmu Ghost in the Shell. Tentokrát v Bashi. Zhlédnout lze online na "ssh ghost@theshell.xyz" [Hacker News].

Ladislav Hagara | Komentářů: 12
včera 20:40 | Zajímavý článek

Lukáš Růžička v článku S Hydrogenem za lepší rytmus aneb bubeníkem snadno a rychle na MojeFedora.cz představuje automatického bubeníka s názvem Hydrogen (Wikipedie): Hydrogen je velmi vydařený program, který rozhodně nesmí chybět ve výbavě žádného linuxového muzikanta. Umožňuje nejen vytváření jednoduchých bicích doprovodů, ale také sofistikované programování bicích a perkusí, jehož výsledek se naprosto vyrovná drahým

… více »
Ladislav Hagara | Komentářů: 13
včera 13:55 | Zajímavý projekt

UPSat (Twitter) je první open source nanodružice (CubeSat). Jedná se o společný projekt nadace Libre Space Foundation a University of Patras. Repozitáře projektu jsou k dispozici na GitHubu. Pod Libre Space Foundation patří také projekt SatNOGS (zprávička), projekt globální sítě open source pozemních satelitních stanic, vítězný projekt soutěže The Hackaday Prize 2014. UPSat je součástí mise QB50 (Twitter). ID UPSatu je GR02. GPS přijímač na UPSatu je od české společnosti SkyFox Labs. Součástí mise QB50 je i česká nanodružice VZLUSAT-1 s ID CZ02.

Ladislav Hagara | Komentářů: 4
21.4. 15:00 | Komunita

V diskusním listu Thunderbird planning vývojáři poštovního klienta Thunderbird řeší, zda by nebylo možné budoucí Thunderbird postavit nad webovými technologiemi, tj. nad Electronem, stejně jako například Nylas Mail. Gecko, nad kterým je Thunderbird postaven, se má hodně změnit. V plánu je odstranění vlastností, které Firefox už nepotřebuje, ale Thunderbird je na nich závislý [Hacker News, reddit].

Ladislav Hagara | Komentářů: 98
21.4. 10:22 | Bezpečnostní upozornění

Společnost Oracle vydala čtvrtletní bezpečnostní aktualizaci svých softwarových produktů (CPU, Critical Patch Update). Opraveno bylo celkově 299 bezpečnostních chyb. V Oracle Java SE je například opraveno 8 bezpečnostních chyb. Vzdáleně zneužitelných bez autentizace je 7 z nich. V Oracle MySQL je opraveno 39 bezpečnostních chyb. Vzdáleně zneužitelných bez autentizace je 11 z nich.

Ladislav Hagara | Komentářů: 8
21.4. 10:00 | Pozvánky

V úterý 25. dubna proběhne další Prague Containers Meetup. Přijďte se nechat inspirovat jak zlepšit build/delivery pipeline vašich kontejnerových aplikací.

little-drunk-jesus | Komentářů: 2
20.4. 21:33 | Komunita

Na Launchpadu se objevilo kódové jméno následující verze Ubuntu. Ubuntu 17.10 bude Artful Aardvark (mazaný hrabáč) [OMG! Ubuntu!].

Ladislav Hagara | Komentářů: 11
20.4. 20:11 | Zajímavý software

MojeFedora.cz informuje, že společnost Nylas oznámila vydání verze 2.0 poštovního klienta Nylas Mail (původně Nylas N1), která již plně podporuje Linux. Obchodní model společnosti je tzv. open core. Samotný klient je open source, ale uživatel si musí připlatit za některé pokročilé funkce. V základu se lze připojit k GMailu nebo libovolnému účtu přes IMAP. Podpora Exchange je pouze v placené verzi. Klient je napsaný nad Electronem.

Ladislav Hagara | Komentářů: 12
20.4. 15:55 | Zajímavý článek

České centrum pro investigativní žurnalistiku (ČCIŽ) publikovalo na svých stránkách článek s názvem Je česká státní správa „rukojmím Microsoftu“?. Drtivá většina české veřejné správy je závislá na výrobcích softwarového gigantu Microsoft – a nijak zvlášť jí to nevadí.

Ladislav Hagara | Komentářů: 21
Chystáte se pořídit CPU AMD Ryzen?
 (4%)
 (35%)
 (0%)
 (7%)
 (44%)
 (9%)
Celkem 286 hlasů
 Komentářů: 32, poslední dnes 12:24
    Rozcestník

    Dotaz: PHP - kontrola mezer v řetězci

    27.6.2015 14:30 VelkyBubak
    PHP - kontrola mezer v řetězci
    Přečteno: 447×
    Jsem si vědom, že podobná otázka tu již padla (http://www.abclinuxu.cz/poradna/programovani/show/328193). Bohužel na ni nebylo odpovězeno a bylo nalezeno jiné řešení.

    udělal jsem si zatím hrubý nástin funkce jíž chci kontrolovat vkládané texty:
    function kontrola_textu($kde) {
    	
    	$kde = trim(strip_tags($kde));
    	
    	$ke_kontrole = strlen($kde);
    	$ke_kontrole2 = floor($ke_kontrole / 2);
    	$znaky = array('0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', ' ', '.', ',', '/', '*', '-', '_', '\\', '!', '?', '(', ')');
    	
    	foreach ($znaky as $znak) {
    	
    	$pocet = substr_count($kde, $znak);
    	
    	if ($pocet > $ke_kontrole2 or $ke_kontrole < 50) return $pocet;
    }
    
    return 0;
    
    }
    
    toto funguje dobře na všechny znaky v poli, kromě mezery. Což mě přivádí k původní otázce.

    Odpovědi

    27.6.2015 14:39 Kit | skóre: 37 | Brno
    Rozbalit Rozbalit vše Re: PHP - kontrola mezer v řetězci
    A jak zní otázka?
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    27.6.2015 15:15 VelkyBubak
    Rozbalit Rozbalit vše Re: PHP - kontrola mezer v řetězci
    och, já zapomněl: Jak zkontrolovat mezery v řetězci? PS: protože se zdá že, mezeru zapsanou takto:
    ' '
    funkce nespatřuje schodnou s mezerou v textu
    27.6.2015 16:52 Kit | skóre: 37 | Brno
    Rozbalit Rozbalit vše Re: PHP - kontrola mezer v řetězci
    Bílých znaků je víc druhů. Tuším, že tam může zlobit chybně použitý "OR".
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    27.6.2015 19:40 VelkyBubak
    Rozbalit Rozbalit vše Re: PHP - kontrola mezer v řetězci
    Netuším zda je or chybně použitý, ale i kdyby, nemá vliv na výsledek kontroly.

    Jakým způsobem tedy mohu otestovat: a) jaká mezera tedy vlastně použita v textu b) všechny možné mezery v textu

    27.6.2015 19:53 Kit | skóre: 37 | Brno
    Rozbalit Rozbalit vše Re: PHP - kontrola mezer v řetězci
    Na výsledek kontroly nemá zřejmě vliv nic, protože jsem zatím nenašel žádný string, pro který by bylo výsledkem nenulové číslo.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    28.6.2015 07:01 VelkyBubak
    Rozbalit Rozbalit vše Re: PHP - kontrola mezer v řetězci
    tak tohle je jen pro začátek (jde o hodnocení a uživatelé musí zadat minimálně 50 znaků), přičemž prvotní záměr tohohle scriptu je, aby nešlo vkládat pitomosti typu: aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa , což je právě ten typ výrazu který dá nenulový výsledek
    28.6.2015 07:06 Kit | skóre: 37 | Brno
    Rozbalit Rozbalit vše Re: PHP - kontrola mezer v řetězci
    Vskutku. A stejně to reaguje i na mezery.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    28.6.2015 07:18 VelkyBubak
    Rozbalit Rozbalit vše Re: PHP - kontrola mezer v řetězci
    Jistě, netvrdím, že to nikomu nemůže fungovat, ale mě to s textem který mi někdo zadá do formuláře (z něhož se POSTem pošle scriptu), pokud jde o mezery prostě nefunguje a tak se snažím přijít na to, jak kontrolovat mezery (a pokud jich je více druhů, jak kontrolovat i ty ostatní)
    28.6.2015 07:27 Kit | skóre: 37 | Brno
    Rozbalit Rozbalit vše Re: PHP - kontrola mezer v řetězci
    Zkus odstranit funkci trim() a pochopíš.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    28.6.2015 20:44 VelkyBubak
    Rozbalit Rozbalit vše Re: PHP - kontrola mezer v řetězci
    Díky. Hezké, takže bude fungovat, pokud do testu přidám rovnost (aby podmínka fungovala s nulou) a v těle if ošetřím možnost $pocet == 0 tak aby nevracela nulu...
    28.6.2015 21:21 Kit | skóre: 37 | Brno
    Rozbalit Rozbalit vše Re: PHP - kontrola mezer v řetězci
    Domnívám se, že někdy je lepší podmínky ubrat, než přidat.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    29.6.2015 08:55 VelkyBubak
    Rozbalit Rozbalit vše Re: PHP - kontrola mezer v řetězci
    takže dáváš přednost tomuto:
    if ($pocet >= $ke_kontrole2) { if ($pocet == 0) {$pocet = 1;} return $pocet;}
    nebo tomuto:
    if ($pocet > $ke_kontrole2) return $pocet;
    if ($pocet == 0) return 1;
    
    Nicméně pořád mám problémy s mezerami:
    function kontrola_textu2($kde) {
    	
    	$kde = trim(strip_tags($kde));
    	
    	$ke_kontrole = strlen($kde);
    	$ke_kontrole2 = floor($ke_kontrole / 2);
    	$znaky = array('0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', ' ', '.', ',', '/', '*', '-', '_', '\\', '!', '?', '(', ')');
    	
    	foreach ($znaky as $znak) {
    	
    	$pocet = substr_count($kde, $znak);
    	
    	if ($pocet >= $ke_kontrole2) { if ($pocet == 0) {$pocet = 1;} return $pocet;}
    }
    
    return 0;
    
    }
    
    $a = "98 g8f98hf hgfh9999999999999999999999999999999999999999999 899999999999999999999999";
    $b = "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa";
    $c = "                                                                                   ";
    
    echo kontrola_textu2($a)."
    "; echo kontrola_textu2($b)."
    "; echo kontrola_textu2($c)."
    "; echo "
    "; echo strlen($a)."
    "; echo strlen($b)."
    "; echo strlen($c)."
    ";
    Výsledky: 68 83 1 83 83 83 a přitom, zadám-li do vstupního pole, na nějž tyto funkce také aplikuji deset mezer jde prý o 18 znaků
    29.6.2015 10:02 Kit | skóre: 37 | Brno
    Rozbalit Rozbalit vše Re: PHP - kontrola mezer v řetězci
    Však ty výsledky jsou správně. Poté, co jsi na string $c aplikoval funkci trim(), je prázdný.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    27.6.2015 20:06 Kit | skóre: 37 | Brno
    Rozbalit Rozbalit vše Re: PHP - kontrola mezer v řetězci
    Proč vlastně přepisuješ formální parametr $kde? Má to nějaký význam? Osobně je považuji za nedotknutelné. Co ta zkratka znamená?
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    28.6.2015 07:11 VelkyBubak
    Rozbalit Rozbalit vše Re: PHP - kontrola mezer v řetězci
    Proč? Nevím proč používat další proměnnou, když mohu tuhle přepsat, zvlášť když původní hodnotu již dále nepotřebuji. Osobně je považuji za zcela normální a i tedy přepisovatelné proměnné.

    PS: není to zkratka, prostě jsem si řekl 'kde kontrolovat' a proměnná získala název. Je pro mě důležité abych se v tom vyznal, a řeším to českými názvy (bez diakritiky pochopitelně)
    28.6.2015 07:32 Kit | skóre: 37 | Brno
    Rozbalit Rozbalit vše Re: PHP - kontrola mezer v řetězci
    Hlavním důvodem však je neztratit kontinuitu, co se ve které proměnné nachází.

    Další proměnou používám i proto, abych ušetřil čas a paměť.

    Bylo by rozumnější pro názvy proměnných používat podstatná jména. Je to důležité pro to, aby ses v tom vyznal.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    29.6.2015 09:04 VelkyBubak
    Rozbalit Rozbalit vše Re: PHP - kontrola mezer v řetězci
    Promiň, ale když použiješ další proměnnou, tak asi moc paměti neušetříš, vlastně bych myslel, že to bude právě naopak. A co se času týká, netuším na co narážíš - jakože přepsat proměnnou je časově náročnější než založit novou?

    Jen tak pro zajímavost, jak ji v daném případě to pojmenoval ty?
    29.6.2015 10:18 Kit | skóre: 37 | Brno
    Rozbalit Rozbalit vše Re: PHP - kontrola mezer v řetězci
    Zkus si udělat pár testů na obsazení paměti v PHP a uvidíš. Ke "přepsání" proměnné nedochází, pokaždé se vytváří nová a ta původní se nechá sežrat v GC. Je tedy praktičtější uvolňovat lokální proměnné naráz při opuštění scope, v našem případě funkce.

    "Přepsáním" formálního parametru se v paměti vytváří jeho klon, aby se originál nepoškodil. Originál tím ve funkci přestane být dostupný, ale v paměti zůstává, protože na něj stále je odkaz skutečného parametru při volání funkce.

    Nejpraktičtější a nejrychlejší je v PHP pracovat s proměnnými tak, jako kdyby byly immutable. Zároveň tím odpadnou problémy se čtením takového programu - zpravidla je v něm méně WTF.

    A pojmenování proměnné? Asi jen "$text", ale vzhledem k tomu, že bych ten vnitřek udělal úplně jinak kvůli rychlosti, měly by ostatní proměnné jiný účel.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    9.7.2015 12:35 Lucius
    Rozbalit Rozbalit vše Re: PHP - kontrola mezer v řetězci
    Nevim jestli jsem dobre pochopil dotaz, pokud ano tak reseni je zhruba takove:
    /*
    $tmpInput - vstupni retezec
    $selectType - co ma fu count_chars vratit  - viz. dokumentace
    
    */
    
    $selectType = 1;
    foreach(count_chars ($tmpInput,$selectType) as $key=>$value){
    	echo '"'.chr($key) . '" - '.$value. "\n";
    }

    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.