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 22:55 | Nová verze

    Byla vydána únorová aktualizace aneb nová verze 1.110 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.110 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 2
    včera 18:11 | IT novinky

    Apple představil 13palcový MacBook Neo s čipem A18 Pro. V základní konfiguraci za 16 990 Kč.

    Ladislav Hagara | Komentářů: 29
    včera 12:22 | Komunita

    Kalifornský zákon AB 1043 platný od 1. ledna 2027 vyžaduje, aby operační systémy požadovaly po uživatelích věk nebo datum narození a skrze API poskytovaly aplikacím informaci, zda je uživatel mladší 13 let, má 13 až 16 let, má 16 až 18 let nebo má alespoň 18 let. Vývojáři linuxových distribucí řeší, co s tím (Ubuntu, Fedora, …).

    Ladislav Hagara | Komentářů: 62
    včera 11:44 | Pozvánky

    Konference LinuxDays 2026 proběhne o víkendu 3. a 4. října v Praze v areálu ČVUT v Dejvicích na FIT. Čekají vás desítky přednášek, workshopy, stánky a setkání se spoustou chytrých lidí.

    Petr Krčmář | Komentářů: 0
    včera 00:44 | Humor

    Nové verze webových prohlížečů Chrome a Firefox jsou vydávány každé 4 týdny. Aktuální verze Chrome je 145. Aktuální verze Firefoxu je 148. Od září přejde Chrome na dvoutýdenní cyklus vydávání. V kterém týdnu bude mít Chrome větší číslo verze než Firefox? 😀

    Ladislav Hagara | Komentářů: 1
    3.3. 21:55 | IT novinky Ladislav Hagara | Komentářů: 4
    3.3. 13:44 | Komunita

    Bylo spuštěno hlasování o přednáškách a workshopech pro letošní Installfest, jenž proběhne o víkendu 28. a 29. března v Praze na Karlově náměstí 13.

    Ladislav Hagara | Komentářů: 3
    3.3. 04:33 | Nová verze

    Byla vydána (Mastodon, 𝕏) třetí RC verze GIMPu 3.2. Přehled novinek v oznámení o vydání. Podrobně v souboru NEWS na GitLabu.

    Ladislav Hagara | Komentářů: 0
    2.3. 21:44 | IT novinky

    Apple představil iPhone 17e a iPad Air s čipem M4.

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

    Byla vydána verze 1.0 editoru kódů Gram. Jedná se o fork editoru Zed bez telemetrie a umělé inteligence.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (17%)
     (6%)
     (0%)
     (11%)
     (28%)
     (2%)
     (5%)
     (1%)
     (13%)
     (25%)
    Celkem 1012 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    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: 1117×
    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.