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 02:44 | Nová verze

Byl vydán Sway ve verzi 0.14. Přehled opravených chyb, změn a novinek v nejnovější verzi tohoto dlaždicového (tiling) správce oken pro Wayland kompatibilního s i3 na GitHubu. Do vývoje se zapojilo 12 vývojářů [reddit].

Ladislav Hagara | Komentářů: 0
včera 22:33 | Nová verze

Byla vydána verze 4.0 svobodného systému pro detekci a prevenci průniků a monitorování bezpečnosti počítačových sítí Suricata (Wikipedie). Přehled novinek v poznámkách k vydání a v aktualizované dokumentaci. Ve dnech 15. až 17. listopadu proběhne v Praze konference vývojářů a uživatelů Suricaty SuriCon 2017.

Ladislav Hagara | Komentářů: 0
včera 17:11 | Nová verze

Byla vydána dvaadvacátá alfa verze svobodné historické realtimové strategie 0 A.D. (Wikipedie). Kódový název této nejnovější verze je Venustas. Představení novinek také na YouTube.

Ladislav Hagara | Komentářů: 3
včera 11:33 | Zajímavý článek

Radek Vokál v článku Boltron – náhled modulárního operačního systému (en) na MojeFedora.cz představuje a informuje o možnosti vyzkoušet si Boltron, prototyp modulární distribuce. Pro Fedoru 26 je k dispozici testovací docker kontejner, který obsahuje modifikovanou verzi správce balíčků DNF, který na pozadí pracuje s moduly.

Ladislav Hagara | Komentářů: 3
včera 07:00 | Nová verze

ZFS on Linux, tj. implementace OpenZFS (Wikipedie) na Linuxu, byl vydán ve verzi 0.7.0. Přehled novinek v diskusním listu zfs-announce nebo na GitHubu. Nejnovější ZFS on Linux je kompatibilní s Linuxem 2.6.32 až 4.12.

Ladislav Hagara | Komentářů: 0
včera 01:44 | IT novinky

V Las Vegas končí bezpečnostní konference Black Hat USA 2017 (Twitter) a začíná bezpečnostní konference DEF CON 25 (Twitter). V rámci Black Hat budou vyhlášeny výsledky letošní Pwnie Awards (Twitter). Pwnie Awards oceňují to nejlepší, ale i to nejhorší z IT bezpečnosti (bezpečnostní Oscar a Malina v jednom). V kategorii "Lamest Vendor Response" byl například nominován také Lennart Poettering za jeho přístup k řešení bezpečnostních chyb v systemd, viz například chyba s uživatelem 0day.

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

Nitay Artenstein z Exodus Intelligence se v příspěvku na blogu společnosti podrobně věnuje bezpečností chybě Broadpwn (CVE-2017-9417). Její analýzu provedl také Zhuowei Zhang na blogu Booster Ok. Jedná se o chybu ve firmwaru Wi-Fi chipsetů BCM43xx od Broadcomu. Útočník může vzdáleně získat kontrolu nad zařízením. Chyba byla již opravena v macOS, iOS i Androidu [Hacker News].

Ladislav Hagara | Komentářů: 3
26.7. 22:55 | IT novinky

Intel končí s vývojovými deskami Joule, Edison, Galileo a také s Arduino 101 a Curie.

Ladislav Hagara | Komentářů: 0
26.7. 14:44 | Nová verze

Byla vydána nová verze 42.3 linuxové distribuce openSUSE Leap. Jedná se už o třetí vydání, které staví na SUSE Linux Enterprise (SLE). Výchozím jádrem je opět poslední LTS verze, tedy řada 4.4. Podrobnosti v oznámení o vydání a v poznámkách k vydání.

Ladislav Hagara | Komentářů: 16
26.7. 14:30 | Nová verze

Google Chrome 60 byl prohlášen za stabilní. Nejnovější stabilní verze 60.0.3112.78 tohoto webového prohlížeče přináší řadu oprav a vylepšení. Vylepšeny byly také nástroje pro vývojáře (YouTube). Opraveno bylo 40 bezpečnostních chyb.

Ladislav Hagara | Komentářů: 0
Těžíte nějakou kryptoměnu?
 (5%)
 (2%)
 (20%)
 (74%)
Celkem 129 hlasů
 Komentářů: 8, poslední včera 21:30
    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.