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 20:22 | Zajímavý článek

Nadace Raspberry Pi vydala již osmapadesáté číslo (pdf) stostránkového anglicky psaného časopisu MagPi věnovanému Raspberry Pi a projektům postaveným na tomto jednodeskovém počítači a druhé číslo (pdf) časopisu Hello World primárně určeného pro učitele informatiky a výpočetní techniky.

Ladislav Hagara | Komentářů: 0
včera 19:55 | Humor

Portál Stack Overflow informuje na svém blogu, že pomohl ukončit editor Vim už více než milionu vývojářů. V loňském roce například hledal odpověď na otázku Jak ukončit editor Vim v průměru 1 z 20 000 návštěvníků.

Ladislav Hagara | Komentářů: 4
včera 19:22 | Nová verze

Po pěti měsících od vydání verze 3.5.0 byla vydána nová stabilní verze 3.6.0, tj. první z nové řady 3.6, minimalistické linuxové distribuce zaměřené na bezpečnost Alpine Linux (Wikipedie). Z novinek lze zmínit například podporu dvou nových 64bitových platforem little-endian POWER machines (ppc64le) a IBM z Systems (s390x) nebo nové balíčky Rust 1.17.0, Cargo 0.18.0, GHC 8.0.2 a Julia 0.5.2.

Ladislav Hagara | Komentářů: 0
24.5. 21:33 | Bezpečnostní upozornění

V Sambě byla nalezena a opravena bezpečnostní chyba CVE-2017-7494. Má-li útočník právo ukládat soubory na vzdálený server, může tam uložit připravenou sdílenou knihovnu a přinutit smbd server k jejímu načtení a tím pádem ke spuštění libovolných příkazů. Chyba je opravena v upstream verzích 4.6.4, 4.5.10 a 4.4.14. Chyba se týká všech verzí Samby od verze 3.5.0 vydané 1. března 2010.

Ladislav Hagara | Komentářů: 3
24.5. 20:44 | Nová verze

Byla vydána nová stabilní verze 4.3.0 integrovaného vývojového prostředí (IDE) Qt Creator. Z novinek lze zmínit například integraci editoru kódu do Qt Quick Designeru.

Ladislav Hagara | Komentářů: 1
24.5. 20:11 | Bezpečnostní upozornění

Společnost Check Point informuje na svém blogu o novém vektoru útoku. Pomocí titulků lze útočit na multimediální přehrávače VLC, Kodi, Popcorn Time, Stremio a pravděpodobně i další. Otevření útočníkem připraveného souboru s titulky v neaktualizovaném multimediálním přehrávači může vést ke spuštění libovolných příkazů pod právy uživatele. Ukázka na YouTube. Chyba je opravena v Kodi 17.2 nebo ve VLC 2.2.6.

Ladislav Hagara | Komentářů: 11
23.5. 15:18 | Zajímavý software

CrossOver, komerční produkt založený na Wine, je dnes (23. 5. 2017) dostupný ve slevě. Roční předplatné linuxové verze vyjde s kódem TWENTYONE na $21, resp. $1 v případě IP z chudších zemí. Firma CodeWeavers, která CrossOver vyvíjí, významně přispívá do Wine. Přidaná hodnota CrossOver spočívá v přívětivějším uživatelském rozhraní, integraci do desktopu a podpoře.

Fluttershy, yay! | Komentářů: 26
23.5. 15:11 | Zajímavý projekt

V únoru loňského roku bylo představeno několik útoků na celou řadu bezdrátových klávesnic a myší s názvem MouseJack. Po více než roce lze chybu opravit, tj. aktualizovat firmware, také z Linuxu. Richardu Hughesovi se podařilo navázat spolupráci se společností Logitech, získat od nich dokumentaci, přesvědčit je, aby firmware poskytovali přímo a ne jako součást .exe souboru, aby mohl být popis začleněn do služby Linux Vendor Firmware Service (LVFS) a aktualizace tak mohla proběhnou přímo z Linuxu pomocí projektu fwupd.

Ladislav Hagara | Komentářů: 2
23.5. 13:22 | Nová verze

Po roce a půl vydali vývojáři projektu SANE (Scanner Access Now Easy) (Wikipedie) novou verzi 1.0.27 balíku SANE-Backends. Nejnovější verze tohoto balíku pro přístup ke skenerům přináší například významná vylepšení v několika backendech nebo podporu pro více než 30 nových modelů skenerů. Verze 1.0.26 byla přeskočena.

Ladislav Hagara | Komentářů: 0
22.5. 20:55 | Komunita

Od 18. do 21. května proběhla v Saint-Étienne Linux Audio Conference 2017. Na programu byla řada zajímavých přednášek a seminářů. Videozáznamy přednášek lze zhlédnout na YouTube. K dispozici jsou také články a prezentace.

Ladislav Hagara | Komentářů: 0
Chystáte se pořídit CPU AMD Ryzen?
 (6%)
 (32%)
 (1%)
 (8%)
 (44%)
 (9%)
Celkem 616 hlasů
 Komentářů: 62, poslední 19.5. 01:57
    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.