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 05:22 | IT novinky

    Nezisková organizace Electronic Frontier Foundation (EFF) hájící občanské svobody v digitálním světě po téměř 20 letech opouští platformu X (dříve Twitter). Na platformách Bluesky, Mastodon, LinkedIn, Instagram, TikTok, Facebook, Threads a YouTube zůstává.

    Ladislav Hagara | Komentářů: 2
    dnes 03:33 | Nová verze

    Terminálový textový editor GNU nano byl vydán ve verzi 9.0. Vylepšuje chování horizontálního posouvání pohledu na dlouhé řádky a chování některých klávesových zkratek. Více v seznamu změn.

    |🇵🇸 | Komentářů: 0
    včera 19:22 | IT novinky

    Ministerstvo financí ve spolupráci s finanční správou dnes představilo beta verzi aplikace využívající umělou inteligenci pro předvyplnění daňového přiznání. Není třeba přepisovat údaje z různých potvrzení, ani hledat správné řádky, kam údaje napsat. Stačí nahrát dokumenty a využít AI.

    Ladislav Hagara | Komentářů: 7
    včera 18:33 | Zajímavý projekt

    Výrobce počítačových periferií Keychron zveřejnil repozitář se schématy šasi klávesnic a myší. Licence je restriktivní, zakazuje většinu komerčních užití a v podstatě jsou tak data vhodná pouze pro výukové účely, hlášení a opravy chyb, případně výrobu vlastního příslušenství.

    |🇵🇸 | Komentářů: 1
    včera 18:22 | Nová verze

    Správce balíčků APT, používaný v Debianu a odvozených distribucích, byl vydán ve verzi 3.2 (seznam změn). Mezi novinkami figurují nové příkazy pro práci s historií, včetně vracení transakcí.

    |🇵🇸 | Komentářů: 0
    včera 14:33 | IT novinky

    Společnost Anthropic oznámila Projekt Glasswing a s ní související AI model Claude Mythos Preview. Jedná se o iniciativu zaměřenou na kybernetickou bezpečnost, do které se zapojily velké technologické společnosti Amazon Web Services, Anthropic, Apple, Broadcom, Cisco, CrowdStrike, Google, JPMorganChase, Linux Foundation, Microsoft, NVIDIA a Palo Alto Networks. Anthropic věří, že nový AI model Claude Mythos Preview dokáže

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

    Firma Ojective Development vydala svůj nástroj pro monitorování a řízení odchozích síťových připojení Little Snitch i pro operační systém Linux. Linuxová verze se skládá ze tří komponent: eBPF program pro zachytávání provozu a webové rozhraní jsou uvolněny pod GNU GPLv2 a dostupné na GitHubu (převážně Rust a JavaScript), jádro backendu je proprietární pod vlastní licencí, nicméně zdarma k použití a redistribuci (cena přitom normálně … více »

    » FIDESZ🧡! « | Komentářů: 0
    8.4. 18:44 | IT novinky

    Vojenské zpravodajství (VZ) se v březnu zapojilo do mezinárodní operace proti aktivitám hackerské skupiny APT28, která je spojovaná s ruskou vojenskou zpravodajskou službou GRU a která přes slabě zabezpečené routery prováděla kybernetické útoky na státní a další organizace v ČR i zahraničí. Operaci vedl americký Federální úřad pro vyšetřování (FBI) a jejím cílem bylo odebrat útočníkům přístup k napadeným zařízením a ty následně … více »

    Ladislav Hagara | Komentářů: 30
    8.4. 16:44 | IT novinky

    Tvůrcem nejpopulárnější kryptoměny bitcoin, který se skrývá za pseudonymem Satoši Nakamoto (Satoshi Nakamoto), je britský kryptograf Adam Back. Na základě vlastní investigativní práce to tvrdí americký deník The New York Times (NYT). Několik indicií podle autorů jasně ukazuje na to, že Back a Nakamoto jsou stejný člověk. Jde mimo jiné o podobný odborný a osobnostní profil či totožné chyby a manýry v psaném projevu.

    Ladislav Hagara | Komentářů: 13
    8.4. 14:44 | Nová verze

    Google Chrome 147 byl prohlášen za stabilní. Nejnovější stabilní verze 147.0.7727.55 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Vylepšeny byly také nástroje pro vývojáře. Přehled novinek v Chrome DevTools 145 až 147 také na YouTube.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (8%)
     (1%)
     (12%)
     (30%)
     (3%)
     (6%)
     (2%)
     (14%)
     (24%)
    Celkem 1256 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: JAVA - rozdelit slovo na pismena

    tomes.io avatar 21.12.2012 13:47 tomes.io | skóre: 12 | blog: tomesh
    JAVA - rozdelit slovo na pismena
    Přečteno: 1118×
    Ahoj, bojuju s rozdelenim slova na jednotliva pismena. Konkretne bych potreboval ze slova(jednoho retezce), kuprikladu:
    M41
    dostat jako vystup :
    M<41>
    . Potrebuju oddelit prvni pismeno a cisla za nim dat do sipek.

    Zkousel jsem :
    slovo.split("")
    s tim ze bych si tam pak ty sipky concatoval, ale ten split() me to na pismena nerozdeli.

    Pokud bych rozdelil slovo na pole charu, tak zas asi tezko concatuju ty sipky...

    Mohl by nekdo poradit pls?

    Řešení dotazu:


    Odpovědi

    21.12.2012 14:15 Franta
    Rozbalit Rozbalit vše Re: JAVA - rozdelit slovo na pismena
    Pokud bych rozdelil slovo na pole charu, tak zas asi tezko concatuju ty sipky...
    Pak to pole projdeš v cyklu a pomocí StringBuilderu postupně sestavíš nový řetězec – na některá místa přidáš ty šipky.

    Měl bys ale upřesnit zadání. Proč chceš šipky přidat zrovna kolem 41? Možná by se ti hodily regulární výrazy – definuješ si vzor, ten může obsahovat skupiny (části textu) a ty si pak vytáhneš a třeba obalíš šipkami.
    tomes.io avatar 21.12.2012 14:45 tomes.io | skóre: 12 | blog: tomesh
    Rozbalit Rozbalit vše Re: JAVA - rozdelit slovo na pismena
    Kolem cisla musi byt sipky. Mam to v zadani. Slouzi to potom pro lepsi parsovani, objekty budou nadale sortovany podle cisel, takze az budu definovat comparTo tak se to bude hodit.

    Kazdopadne nakonec jsem to vyresil pres regularni vyrazy, jak jsi rekl. Dostal jsem diky tomu aspon String s cislem, coz uz mi pomohlo:
    char[] charArray = word.toCharArray();
    String temp = Character.toString(charArray[0]); //getting object letter
                    
    Pattern pattern = Pattern.compile("^"+temp+"(\\d+)$"); //setting a regex pattern
    Matcher matcher = pattern.matcher(word);
        
    if(!(matcher.matches())) {
                        
        throw new CatalogIOException("wrong ID format");
    }
                    
                            
    String ID = temp.concat("<").concat(matcher.group(1)).concat(">"); //matcher.gorup(1) returns a string with the object number
    
    xkucf03 avatar 21.12.2012 16:39 xkucf03 | skóre: 50 | blog: xkucf03
    Rozbalit Rozbalit vše Re: JAVA - rozdelit slovo na pismena
    Tak v druhém kroku můžeš zkusit OOP :-) Místo vymýšlení nějakého pseudojazyka s čísly v závorkách z toho udělej instance nějaké tvé třídy, kde to číslo bude uložené jako int v privátní proměnné.
    Mám rád, když se lidé přou, znamená to, že vědí, co dělají, a že mají směr. Frantovo.cz, SQL-DK, Relational pipes
    Řešení 1× (danaketh)
    22.12.2012 16:57 ::: | skóre: 14 | blog: e_lama
    Rozbalit Rozbalit vše Re: JAVA - rozdelit slovo na pismena
    jsou v jave regexy?

    v perlu bych to napsal takhle:
    s/^([a-z])([0-9]+)/$1<$2>/i;
    
    xkucf03 avatar 22.12.2012 19:06 xkucf03 | skóre: 50 | blog: xkucf03
    Rozbalit Rozbalit vše Re: JAVA - rozdelit slovo na pismena
    Ano, součástí základní knihovny Javy SE jsou regulární výrazy. Napíšeš to třeba takhle:
    "M41".replaceAll("([0-9]+)", "<$1>")
    (a při opakovaném použití je dobré si regulární výrazy předkompilovat)
    Mám rád, když se lidé přou, znamená to, že vědí, co dělají, a že mají směr. Frantovo.cz, SQL-DK, Relational pipes
    28.3.2013 14:37 Robo
    Rozbalit Rozbalit vše Re: JAVA - rozdelit slovo na pismena
    public static String updateText(String str) {
            StringBuffer updatedText = new StringBuffer();
            Matcher matcher = Pattern.compile("\\d+").matcher(str);
            while(matcher.find()) {
                String group = matcher.group();
                StringBuilder replacement = new StringBuilder();
                replacement.append("<").append(group).append(">");
                matcher.appendReplacement(updatedText, replacement.toString());
            }
            matcher.appendTail(updatedText);
            return updatedText.toString();
    }
    
    28.3.2013 15:32 DarkKnightCZ | skóre: 12
    Rozbalit Rozbalit vše Re: JAVA - rozdelit slovo na pismena

    no to potes, takova prasarna... proc navic komentujete 100 dni stary dotaz, kde navic padlo elegantni reseni?

    28.3.2013 21:42 Nobody
    Rozbalit Rozbalit vše Re: JAVA - rozdelit slovo na pismena
    Vubec jste nepochopil vtip.
    28.3.2013 21:52 potato
    Rozbalit Rozbalit vše Re: JAVA - rozdelit slovo na pismena
    Žádný vtip tady není. Jen nesmyslný komentář sto dní starého dotazu.
    1.4.2013 20:10 R
    Rozbalit Rozbalit vše Re: JAVA - rozdelit slovo na pismena
    No az taka "prasarna" to teda nie je, pretoze moja funkcia je o polovicu rychlejsia pri kratkych Stringoch, pri dlhych Stringoch sa to vyrovnava s Tvojim "elegantnym resenim". Este lepsie je ale pouzit pri velmi velkych Stringoch/suboroch Scanner (hasNextInt() + nextInt()), ktory sa da napojit na input stream a nezadrbavat pamat. Ale uznavam, ze 1 riadkova funkcia je elegantna.

    import java.util.Date;
    import java.util.regex.Matcher;
    import java.util.regex.Pattern;
    
    public class Test {
    
        private static final String TEST_STRING = "M23";
    
        public static void main(String[] args) {
            Date d = new Date();
            Pattern pattern = Pattern.compile("\\d+");
    
            for(int i = 0; i < 10000000; i++) {
                TEST_STRING.replaceAll("([0-9]+)", "<$1>");
    
            }
    
            System.out.println(new Date().getTime() - d.getTime());
    
            d = new Date();
    
            for(int i = 0; i < 10000000; i++) {
                updateText(pattern, TEST_STRING);
            }
    
            System.out.println(new Date().getTime() - d.getTime());
    
        }
    
        public static String updateText(Pattern pattern, String str) {
            StringBuffer updatedText = new StringBuffer();
            Matcher matcher = pattern.matcher(str);
            while(matcher.find()) {
                String group = matcher.group();
                StringBuilder replacement = new StringBuilder();
                replacement.append("<").append(group).append(">");
                matcher.appendReplacement(updatedText, replacement.toString());
            }
            matcher.appendTail(updatedText);
            return updatedText.toString();
        }
    
    }
    
    

    1.4.2013 22:01 R
    Rozbalit Rozbalit vše Re: JAVA - rozdelit slovo na pismena
    Sorac, samozrejme v teste ma byt kompilacia patternu pred prvym Date d = new Date(); Vysvetlenie ale plati. Na priklade a na mojej masine 7 sekund (dlha fkcia) vs 4 sekundy (1 riadkovy replaceAll).
    1.4.2013 22:20 R
    Rozbalit Rozbalit vše Re: JAVA - rozdelit slovo na pismena
    7 sekund replaceAll vs 4 sekundy dlha fkcia.

    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.