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 18:11 | Zajímavý software

    Nazdar! je open source počítačová hra běžící také na Linuxu. Zdrojové kódy jsou k dispozici na GitHubu. Autorem je Michal Škoula.

    Ladislav Hagara | Komentářů: 0
    včera 16:55 | Nová verze

    Po více než třech letech od vydání verze 1.4.0 byla vydána nová verze 1.5.0 správce balíčků GNU Guix a na něm postavené stejnojmenné distribuci GNU Guix. S init systémem a správcem služeb GNU Shepherd. S experimentální podporou jádra GNU Hurd. Na vývoji se podílelo 744 vývojářů. Přibylo 12 525 nových balíčků. Jejich aktuální počet je 30 011. Aktualizována byla také dokumentace.

    Ladislav Hagara | Komentářů: 2
    včera 15:44 | Zajímavý software

    Na adrese gravit.huan.cz se objevila prezentace minimalistického redakčního systému GravIT. CMS je napsaný ve FastAPI a charakterizuje se především rychlým načítáním a jednoduchým ukládáním obsahu do textových souborů se syntaxí Markdown a YAML místo klasické databáze. GravIT cílí na uživatele, kteří preferují CMS s nízkými nároky, snadným verzováním (např. přes Git) a možností jednoduchého rozšiřování pomocí modulů. Redakční

    … více »
    2012 | Komentářů: 0
    včera 12:55 | Zajímavý software

    Tým Qwen (Alibaba Cloud) uvolnil jako open-source své modely Qwen3‑TTS pro převádění textu na řeč. Sada obsahuje modely VoiceDesign (tvorba hlasu dle popisu), CustomVoice (stylizace) a Base (klonování hlasu). Modely podporují syntézu deseti různých jazyků (čeština a slovenština chybí). Stránka projektu na GitHubu, natrénované modely jsou dostupné na Hugging Face. Distribuováno pod licencí Apache‑2.0.

    NUKE GAZA! 🎆 | Komentářů: 0
    včera 01:11 | Nová verze

    Svobodný citační manažer Zotero (Wikipedie, GitHub) byl vydán v nové major verzi 8. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    22.1. 16:55 | Nová verze

    Byla vydána verze 1.93.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    22.1. 14:00 | Komunita

    Svobodný operační systém ReactOS (Wikipedie), jehož cílem je kompletní binární kompatibilita s aplikacemi a ovladači pro Windows, slaví 30. narozeniny.

    Ladislav Hagara | Komentářů: 8
    22.1. 11:00 | IT novinky

    Společnost Raspberry Pi má nově v nabídce flash disky Raspberry Pi Flash Drive: 128 GB za 30 dolarů a 256 GB za 55 dolarů.

    Ladislav Hagara | Komentářů: 2
    22.1. 10:22 | Zajímavý software

    Technologie Skip pro multiplatformní mobilní vývoj, která umožňuje vývojářům vytvářet iOS a Android aplikace z jediné Swift a SwiftUI kódové základny, se s vydáním verze 1.7 stala open source.

    Ladislav Hagara | Komentářů: 6
    22.1. 03:33 | Zajímavý software Ladislav Hagara | Komentářů: 1
    Které desktopové prostředí na Linuxu používáte?
     (17%)
     (6%)
     (0%)
     (10%)
     (21%)
     (3%)
     (5%)
     (2%)
     (11%)
     (35%)
    Celkem 583 hlasů
     Komentářů: 17, poslední 22.1. 15:24
    Rozcestník

    Dotaz: [PHP] Jak zapsat regularni vyraz, aby to vzalo vsechny znaky i s \n?

    20.1.2006 18:26 babca
    [PHP] Jak zapsat regularni vyraz, aby to vzalo vsechny znaky i s \n?
    Přečteno: 349×
    Jak zapsat regularni vyraz, aby to vzalo vsechny znaky i s \n?

    "Vsechny" znaky se zapisou: . Znak konce radku je \n (v uvozovkach tedy \\n) Jak ale napsat, aby mi parser vzal uplne vsechny znaky i s konci radku?

    Dik..

    Odpovědi

    20.1.2006 18:55 machr
    Rozbalit Rozbalit vše Re: [PHP] Jak zapsat regularni vyraz, aby to vzalo vsechny znaky i s \
    .|\\n
    
    nejsem si jistej, ale . (tecka) by mela znamenat vsechny znaky vcetne znaku konce radku
    20.1.2006 21:07 babca
    Rozbalit Rozbalit vše Re: [PHP] Jak zapsat regularni vyraz, aby to vzalo vsechny znaky i s \
    Snažím se použít následující (všimněte si (.+), tím zbytkem se nezabývejte):

    $text = preg_replace("|\[$tag_name\](.+)\[/$tag_end\]|i", $replace[open]."\\1".$replace[close], $text)

    No a podle stránky http://www.root.cz/clanky/regularni-vyrazy-1/
    "....Tuto činnost obstará znak tečka (.). Při hledání jí vyhoví libovolný znak kromě konce řádku. ...."

    Tak jsem se snažil nahradit (.+) za něco ve stylu .|\\n - jak říkás - u mě tedy nějak takto - ([.|\\n]+), ale to mi php nebere!

    $text = preg_replace("|\[$tag_name\]([.|\\n]+)\[/$tag_end\]|i", $replace[open]."\\1".$replace[close], $text);
    Pomůže někdo? Kde je chyba? Dík...
    20.1.2006 22:14 machr
    Rozbalit Rozbalit vše Re: [PHP] Jak zapsat regularni vyraz, aby to vzalo vsechny znaky i s \

    zkuste tohle. nejsem si jistej, jestli u toho \n opravdu prijdou 2 zpetny lomitka jak pisete ve vasem puvodnim prispevku.

    $text = preg_replace("|\[$tag_name\](((.)|(\n))+)\[/$tag_end\]|i", $replace[open]."\\1".$replace[close], $text);
    

    par zavorek navic nikdy neuskodi ;)

    symbol '|' znamena 'nebo'. takze '.|\n' znamena tecka (libovolnej znak) nebo \n

    PS: pokud date cokoli do hranatych zavorek (vcetne tecky) tak je to mysleno jako libovolny 1 znak z tyhle zavorky

    20.1.2006 22:51 babca
    Rozbalit Rozbalit vše Re: [PHP] Jak zapsat regularni vyraz, aby to vzalo vsechny znaky i s \
    No a do hranatych zavorek se zadavaji povolene znaky, tak [.|\n]

    nekde jsem se stejne docet, ze ma byt \\n - stejne jako u \\1, \\2 - vstupni udaj ma byt \n (resp. \1, \2) - a aby se mohl napsat v php do uvozovek, musi se zpetna lomitka zdvojit.

    Jinak tvoje reseni zase nefunguje... :-(, zkousel jsem taky jeste plno dalsich variant jak toho myho, tak tvyho, ale stale to konci chybou typu Warning: Unknown modifier '\' in .... on line ...

    vadi mu aj ([u|a]+) atd, co delam spatne?

    jo a taky jsme se docet, ze kdyz je v hranatych zavorkach tecka, tak zastupuje normalni tecku... no nevim...
    21.1.2006 00:44 machr
    Rozbalit Rozbalit vše Re: [PHP] Jak zapsat regularni vyraz, aby to vzalo vsechny znaky i s \

    jak se na to divam, tak je tam spatne vic veci...

    1. funkce preg_replace ocekava jako prvni 2 parametry pole vyrazu a nahrad. pokud pro ni nemas nejaky specialni duvod, pouzi misto ni ereg_replace().

    2. ta chyba co ti to pise je vlastne varovani, ze tam mas neznamou escape-sequenci - treba hned to prvni \[ tusim neni platna. Zrejme tam patri dve lomitka jak u toho \n.

    tohle napr funguje:

    	$text = "
    	machr<br>
    	[xxx]<br>
    <br>
    	[/xxx]<br>
    	rulezzz<br>
    	";
    
    	print $text; print "<br>";
    	print "################################<br>";
    
    	$text = ereg_replace("\\[xxx\\](.|\\n)+\\[/xxx\\]", "REPLACED", $text);
    
    	print $text; print "<br>";
    
    VYSTUP:
    machr
    [xxx]
    
    [/xxx]
    rulezzz
    
    ################################
    machr
    REPLACED
    rulezzz
    

    teda, jestli sem pochopil spravne, ze to ma najit a nahradit vsechny retezce typu:

    [xxx] .... [/xxx]
    

    PS: pokud das do hranatych zavorek libovolny symbol (takze i tecku) tak zastupuje prave ten symbol a jeho specialni funkce je zrusena.

    21.1.2006 14:33 babča [www.oplatek.org]
    Rozbalit Rozbalit vše Re: [PHP] Jak zapsat regularni vyraz, aby to vzalo vsechny znaky i s \
    Hele moc dík, že sis s tím dal takovou práci...

    Ja byl pořád v domnění, že sviská čárka ( | ) se používá jen v oněch hranatých závorkách... :-)

    To by mohlo fungovat... asi nejsprávnější odpověď však našel halogen - modifikátor "s" - funguje to bezvadně...

    našl jsem ho vysvětlený třeba na (PHP.net)

    $text = preg_replace("|\[$tag_name\](.+)\[/$tag_end\]|Uis", $replace[open].$vlozit.$replace[close], $text);

    Jinak, s tema hranatyma zavorkama, to je zajimavy - ted nad tim premyslim...jaktoze to funguje s jednim lomitkem?

    Ano, poznals správně, tento kód je pro převod značek do html... :-)

    function nahradit_znacky_za_html ($text, $target_blank = "ne")
    {
    if ($target_blank == "ano")
    {
    $target_blank = "target='_blank'";
    }
    else
    {
    $target_blank = "";
    }

    $tag_array["b"] = array("open"=>"<b>", "close"=>"</b>");
    $tag_array["i"] = array("open"=>"<i>", "close"=>"</i>");
    $tag_array["u"] = array("open"=>"<u>", "close"=>"</u>");
    $tag_array["img"] = array("open"=>"<img src='", "close"=>"'>");
    $tag_array["mail=(.+)"] = array("open"=>"<a href='mailto:", "close"=>"'>\\2</a>");
    $tag_array["color=(.+)"] = array("open"=>"<span style='color: ", "close"=>"'>\\2</span>");
    $tag_array["size=(.+)"] = array("open"=>"<span style='font-size: ", "close"=>"'>\\2</span>");
    $tag_array["font=(.+)"] = array("open"=>"<span style='font-family: ", "close"=>"'>\\2</span>");
    $tag_array["url"] = array("open"=>"<a href='", "close"=>"' ".$target_blank.">\\1</a>");
    $tag_array["url=(.+)"] = array("open"=>"<a href='", "close"=>"' ".$target_blank.">\\2</a>");
    //$tag_array["url=?(http://)(.+)"] = array("open"=>"<a href='http://", "close"=>"' >\\2</a>");

    $tag_array["quote=(.+)"] = array("open"=>"<div class='komentare-diskuze-puvodni-autor'>\\1 napsal:</div><div class='komentare-diskuze-puvodni-text'>", "close"=>"</div></div>");

    foreach($tag_array as $tag_name=>$replace)
    {
    if (ereg("quote=.+", $tag_name))
    {
    $vlozit = "\\2";
    }
    else
    {
    $vlozit = "\\1";
    }

    $tag_end = preg_replace("/\W/Ui", "", $tag_name);
    $text = preg_replace("|\[$tag_name\](.+)\[/$tag_end\]|Uis", $replace[open].$vlozit.$replace[close], $text);
    }

    $text = str_replace("[hr]", "<<hr size='1' noshade>", $text);
    $text = str_replace("[br]", "<br />\n", $text);

    return $text;
    }

    jen jetě řeším, jak automaticky doplnit http:// do značek, kde adresa odkazu zčíná jen třeba www (bez http://)... Snažil jsem se o to na zakomentovaném řádku, ale to mi nejede (jak jinak, že)
    21.1.2006 10:11 Marek:)
    Rozbalit Rozbalit vše Re: [PHP] Jak zapsat regularni vyraz, aby to vzalo vsechny znaky i s \n?
    Asi je to tím, že regulární výrazy perlu, z kterých vychází php, tečku nezahrnují. viz http://www.linuxsoft.cz/article.php?id_article=1000
    21.1.2006 11:36 halogan | skóre: 7 | Praha
    Rozbalit Rozbalit vše Snadné řešení
    Modifikátor s :) |regexp|s
    vim isn't just for nerds

    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.