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 18:11 | Nová verze

Společnost Oracle oficiálně oznámila vydání Java SE 9 (JDK 9), Java Platform Enterprise Edition 8 (Java EE 8) a Java EE 8 Software Development Kit (SDK). Java SE 9 přináší více než 150 nových vlastností.

Ladislav Hagara | Komentářů: 0
dnes 12:11 | Komunita

Na Humble Bundle lze získat hororovou počítačovou hru Outlast (Wikipedie) běžící také v Linuxu zdarma. Speciální akce končí v sobotu v 19:00.

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

Mozilla.cz upozorňuje na Knihu Mozilly (Wikipedie), tj. velikonoční vajíčko ve Firefoxu. Zobrazit jej lze zadáním about:mozilla do adresního řádku. Aktuální verze Firefoxu obsahuje proroctví 15:1 "Dvojčata Mamonu se rozhádala a jejich souboje uvrhly svět do nové tmy. Zvířeti se ale tma hnusila. A tak se stalo mrštnější a silnější, šlo vpřed a jeho počty rostly. A zvíře přineslo oheň a světlo do tmy". Firefox 57 bude obsahovat proroctví 11:14. To je zatím jenom v angličtině. Pomoci lze s překladem do češtiny.

Ladislav Hagara | Komentářů: 6
dnes 01:22 | Zajímavý projekt
Před měsícem byla spuštěna kampaň na podporu chytrého telefonu Librem 5, jenž by měl respektovat bezpečnost, svobodu a soukromí uživatelů. Cílem kampaně je vybrat alespoň milion a půl dolarů. Aktuálně je vybráno přes 600 000 dolarů, tj. 40 %. Kampaň poběží ještě další měsíc. Podporu projektu oznámilo KDE i GNOME.
Ladislav Hagara | Komentářů: 22
dnes 00:55 | Komunita

Agentura DISA (Defense Information Systems Agency) publikovala (pdf) Ubuntu 16.04 Security Technical Implementation Guide (STIG) (zip), tj. doporučené bezpečnostní nastavení Ubuntu 16.04. Ubuntu se tak dostalo mezi unixové operační systémy a linuxové distribuce AIX, HP-UX, Oracle Linux, Red Hat a Solaris [reddit].

Ladislav Hagara | Komentářů: 1
včera 22:55 | Bezpečnostní upozornění

CSIRT.CZ informuje, že byly vydány nové bezpečnostní aktualizace, které opravují několik zranitelných míst v Sambě. Útočník může využít zranitelnosti s cílem získání přístupu k potenciálně citlivých informací. Uživatelům a správcům je doporučeno, aby zkontrolovali bezpečnostní opatření pro CVE-2017-12150, CVE-2017-12151 a CVE-2017-12163 a provedli potřebné aktualizace.

Ladislav Hagara | Komentářů: 0
včera 21:44 | Komunita

Společnost Red Hat aktualizovala svůj slib ohledně softwarových patentů. Slib nově zahrnuje i open source software pod permisivními licencemi.

Ladislav Hagara | Komentářů: 0
včera 08:55 | Komunita

Do 22. září probíhá v Mountain View konference XDC2017 (X.Org Developer's Conference). Na programu je řada zajímavých přednášek. Sledovat je lze online. K dispozici je záznam přednášek ze včerejšího dne.

Ladislav Hagara | Komentářů: 0
20.9. 17:33 | Nová verze

Byla vydána nová stabilní verze 1.12 (1.12.955.36) webového prohlížeče Vivaldi (Wikipedie). Z novinek vývojáři zdůrazňují možnost zobrazení metadat u digitálních fotografií, vylepšený panel stahování a omezení sytosti barvy zdůraznění (YouTube). Nejnovější Vivaldi je postaveno na Chromiu 61.0.3163.91.

Ladislav Hagara | Komentářů: 40
20.9. 10:55 | Nová verze

Byla vydána verze 4.0 programovacího jazyka Swift (Wikipedie). Zdrojové kódy jsou k dispozici na GitHubu. Ke stažení jsou oficiální binární balíčky pro Ubuntu 16.10, Ubuntu 16.04 a Ubuntu 14.04.

Ladislav Hagara | Komentářů: 5
Těžíte nějakou kryptoměnu?
 (5%)
 (3%)
 (17%)
 (75%)
Celkem 557 hlasů
 Komentářů: 22, poslední 29.8. 11:23
    Rozcestník

    Dotaz: PHP - kontrola mezer v řetězci

    27.6.2015 14:30 VelkyBubak
    PHP - kontrola mezer v řetězci
    Přečteno: 448×
    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: 38 | 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: 38 | 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: 38 | 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: 38 | 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: 38 | 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: 38 | 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: 38 | 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: 38 | 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: 38 | 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: 38 | 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.