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:11 | Komunita

    Všem čtenářkám a čtenářům AbcLinuxu krásné Vánoce.

    Ladislav Hagara | Komentářů: 8
    dnes 02:00 | Nová verze

    Byla vydána nová verze 7.0 linuxové distribuce Parrot OS (Wikipedie). S kódovým názvem Echo. Jedná se o linuxovou distribuci založenou na Debianu a zaměřenou na penetrační testování, digitální forenzní analýzu, reverzní inženýrství, hacking, anonymitu nebo kryptografii. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 1
    včera 18:33 | Nová verze

    Vývojáři postmarketOS vydali verzi 25.12 tohoto před osmi lety představeného operačního systému pro chytré telefony vycházejícího z optimalizovaného a nakonfigurovaného Alpine Linuxu s vlastními balíčky. Přehled novinek v příspěvku na blogu. Na výběr jsou 4 uživatelská rozhraní: GNOME Shell on Mobile, KDE Plasma Mobile, Phosh a Sxmo.

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

    Byla vydána nová verze 0.41.0 multimediálního přehrávače mpv (Wikipedie) vycházejícího z přehrávačů MPlayer a mplayer2. Přehled novinek, změn a oprav na GitHubu. Požadován je FFmpeg 6.1 nebo novější a také libplacebo 6.338.2 nebo novější.

    Ladislav Hagara | Komentářů: 0
    včera 12:44 | Nová verze

    Byla vydána nová verze 5.5 (novinky) skriptovacího jazyka Lua (Wikipedie). Po pěti a půl letech od vydání verze 5.4.

    Ladislav Hagara | Komentářů: 0
    22.12. 23:44 | Nová verze

    Byla vydána nová verze 5.4.0 programu na úpravu digitálních fotografií darktable (Wikipedie). Z novinek lze vypíchnout vylepšenou podporu Waylandu. Nejnovější darktable by měl na Waylandu fungovat stejně dobře jako na X11.

    Ladislav Hagara | Komentářů: 0
    21.12. 05:00 | Nová verze

    Byla vydána beta verze Linux Mintu 22.3 s kódovým jménem Zena. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze, že nástroj Systémová hlášení (System Reports) získal mnoho nových funkcí a byl přejmenován na Informace o systému (System Information). Linux Mint 22.3 bude podporován do roku 2029.

    Ladislav Hagara | Komentářů: 2
    21.12. 01:55 | Nová verze

    GNU Project Debugger aneb GDB byl vydán ve verzi 17.1. Podrobný přehled novinek v souboru NEWS.

    Ladislav Hagara | Komentářů: 0
    19.12. 17:22 | IT novinky

    Josef Průša oznámil zveřejnění kompletních CAD souborů rámů tiskáren Prusa CORE One a CORE One L. Nejsou vydány pod obecnou veřejnou licenci GNU ani Creative Commons ale pod novou licencí OCL neboli Open Community License. Ta nepovoluje prodávat kompletní tiskárny či remixy založené na těchto zdrojích.

    Ladislav Hagara | Komentářů: 14
    19.12. 17:00 | Komunita

    Nový CEO Mozilla Corporation Anthony Enzor-DeMeo tento týden prohlásil, že by se Firefox měl vyvinout v moderní AI prohlížeč. Po bouřlivých diskusích na redditu ujistil, že v nastavení Firefoxu bude existovat volba pro zakázání všech AI funkcí.

    Ladislav Hagara | Komentářů: 1
    Kdo vám letos nadělí dárek?
     (30%)
     (1%)
     (10%)
     (3%)
     (1%)
     (3%)
     (13%)
     (23%)
     (14%)
    Celkem 69 hlasů
     Komentářů: 17, poslední dnes 00:24
    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: 1110×
    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: 49 | 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: 49 | 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.