Rozšírenie pre vkladanie čísla slovom

doplnek.png Potrebujete vo svojich dokumentoch v module Writer alebo v module Calc vkladať čísla slovom (slovensky alebo česky)? Nainštalujte si rozšírenie JP Prevod čísla na slovenské a české slovo, ktoré to urobí za vás.  

Veľké množstvo používateľov potrebuje vo svojich dokumentoch vkladať čísla slovom, napríklad (ale nielen) v príjmových a výdavkových pokladničných dokladoch, ktoré boli zverejnené na portáli Inet.sk ako v slovenskom, tak aj v českom jazyku. Pre nich sme pripravili rozšírenie JP Prevod čísla na slovenské a české slovo v aktuálnej verzii 2010.08.30.

Úvod do problematiky prevodu čísiel na slová

Skôr ako popíšeme vlastné rozšírenie, musíme sa trochu venovať problematike prevodu čísiel na slová. Zdanlivo jednoduchá záležitosť totiž skrýva v sebe veľa otázok a rôznych variánt. V prvom rade je potrebné zabezpečiť prevod čísla na slovo tak, ako sa správne píše po gramatickej stránke, t.j. s medzerami medzi (samozrejme, s osobitnými pravidlami písania medzier v slovenčine a češtine). Aj v tomto prípade však potrebujete, aby sa slovo raz napísalo s malým počiatočným písmenom a inokedy s veľkým.

Ďalšiu kapitolu tvoria tzv. finančné čísla, kde sa píšu číslovky 100, 1000 apod. s číslom „jedna“ na začiatku – jednosto, jedentisíc. Pravdaže, aj v prípade finančných čísloviek môžete potrebovať, aby sa písali s malým alebo veľkým počiatočným písmenom. Okrem toho však práve (ale nielen) pri finančných číslovkách mnohokrát potrebujete, aby sa nepísali s medzerami, ale ako jedno slovo. Toto pravidlo je zavedené z toho dôvodu, aby sa nemohlo do takéhoto slova nič vpísať (preto sa vlastne píše aj číslo „jedna“ na začiatku finančných čísiel).

Aby však problematika nebola až taká jednoduchá, ak píšete čísla spolu s finančnou menou, musíte čísla skloňovať, pretože je „jedno euro“, ale „jeden cent“ („jedna koruna“, ale „jeden halíř“). Navyše, v prípade meny sa musí skloňovať aj samotná mena, pretože je „jedno euro“, ale „dve eurá“ („jedna koruna“, ale „dvě koruny“).

Pravdaže, skloňovanie nie je viazané iba na finančnú menu – pokiaľ píšete čísla spolu so slovami „celé“ či „desatiny“, musíte skloňovať aj tieto slová – „jedna celá tri stotiny“, ale „dve celé päť stotín“ („jedna celá tři setiny“, ale „dvě celé pět setin“).

Toľko na úvod k problematike a teraz sa už venujme vlastnému rozšíreniu JP Prevod čísla na slovenské a české slovo. Skôr, než sa naň pozrieme podrobnejšie, musíme uviesť, že maximálne číslo, ktoré je možné previesť na reťazec je 2147483647 – „Dve miliardy stoštyridsaťsedem miliónov štyristoosemdesiattritisíc šesťstoštyridsaťsedem“ („Dvě miliardy sto čtyřicet sedm miliónů čtyři sta osmdesát tři tisíc šest set čtyřicet sedm“), čo je dané možnosťami jazyka OpenOffice.org Basic.

Vkladanie čísiel slovami v OpenOffice.org Writer

Po nainštalovaní rozšírenia sa vložia do prostredia OpenOffice.org Writer štyri panely nástrojov – JP SK/CS číslo na slovo - bez meny, JP SK/CS číslo na slovo - celá, desatina, JP SK/CS číslo na slovo - euro, cent a JP SK/CS číslo na slovo - koruna, halier. Panely nástrojov sú jazykovo lokalizované do slovenčiny, češtiny a angličtiny (aj keď rozšírenie nevkladá slová anglicky).

Panely nástrojov pre vkladanie čísla slovomPanely nástrojov pre vkladanie čísla slovom

Panely nástrojov zodpovedajú rôznym „finančným“ menám – prvý vkladá slová čísiel bez jej uvedenia; druhý za slovné znenie čísiel vloží slová „celá“, „desatina“, „stotina“...; tretí za slovné znenie čísiel vloží menu „euro“, „cent“ a štvrtý vloží okrem vlastného čísla aj menu „koruna“, „halier“. Vkladanie slovenských a českých slov je automatizované podľa aktuálneho jazyka čísla, ktoré prevádzate na slovo – t.j. ak je napísané slovensky, vloží sa slovné znenie po slovensky, ak je napísané česky, vloží sa slovné znenie česky. V prípade akýchkoľvek iných jazykov sa neprevedie žiadna akcia.

Prevod označeného čísla (s desatinnou bodkou) na slovoPrevod označeného čísla (s desatinnou bodkou) na slovo

Pre prevod čísla stačí, ak ho napíšete a stlačíte príslušné tlačidlo na niektorom z panelov nástrojov. Pokiaľ pri prevode označíte číslovku, prevedie sa takto označené číslo, inak sa pre prevod použije posledné slovo, na ktorom alebo za ktorým sa nachádzate. Pozor, rozšírenie v číslach považuje desatinnú čiarku a bodku za rovnocenné znaky, a preto pri vkladaní čísiel neoddeľujte rády bodkou – bola by považovaná za desatinnú bodku.

Označené číslo po prevode na slovoOznačené číslo po prevode na slovo

To, že môžete slovo pri prevode označiť , má svoje výhody – v tomto prípade totiž môžete rády oddeliť medzerou (pri prevode sú ignorované). Pokiaľ slovo neoznačíte, automatika rozoznávania posledného slova považuje medzeru za oddeľovač, a preto by sa takto napísané číslo nepreviedlo správne.

Aktuálne slovo (číslo s desatinnou čiarkou) – kurzor je niekoľko medzier za týmto číslomAktuálne slovo (číslo s desatinnou čiarkou) – kurzor je niekoľko medzier za týmto číslom

Na druhej strane je prevod neoznačeného slova rýchlejší (nemusíte sa zdržovať jeho označovaním) a kurzor sa dokonca môže nachádzať aj niekoľko medzier za ním – po prevode sa jeho poloha nezmení.

Aktuálne slovo (číslo) po prevode na slovoAktuálne slovo (číslo) po prevode na slovo

Tlačidla na paneli nástrojov zodpovedajú rôznym spôsobom prevodu, ktoré sme spomenuli v úvode – nastavenia sú napísané v bublinovom pomocníkovi, ktorý sa zobrazuje pri prechode na príslušné tlačidlo. Pretože všetky panely sú podobné, uvedieme ako príklad všetky možnosti na paneli JP SK/CS číslo na slovo - koruna, halier:

  • sto korun dvacet tři halířů – prvé písmeno malé, čísla sa píšu s medzerami, typ meny „koruna, halier“.
  • Sto korun Dvacet tři halířů – prvé písmeno veľké, čísla sa píšu s medzerami, typ meny „koruna, halier“.
  • sto korun dvacettři halířů – prvé písmeno malé, čísla sa píšu spolu bez medzier, typ meny „koruna, halier“.
  • Sto korun Dvacettři halířů – prvé písmeno veľké, čísla sa píšu spolu bez medzier, typ meny „koruna, halier“.
  • jednosto korun dvacet tři halířů – finančné čísla, prvé písmeno malé, čísla sa píšu s medzerami, typ meny „koruna, halier“.
  • Jednosto korun Dvacet tři halířů – finančné čísla, prvé písmeno veľké, čísla sa píšu s medzerami, typ meny „koruna, halier“.
  • jednosto korun dvacettři halířů – finančné čísla, prvé písmeno malé, čísla sa píšu spolu bez medzier, typ meny „koruna, halier“.
  • Jednosto korun Dvacettři halířů – finančné čísla, prvé písmeno veľké, čísla sa píšu spolu bez medzier, typ meny „koruna, halier“.

Na záver popisu rozšírenia pre modul OpenOffice.org Writer ešte upozorňujeme, že pri prevode „bez meny“ sa prevádza na slovo iba celá časť čísla, pretože prevod typu „stodvadsaťtri štyridsaťpäť“ nemá zmysel, ale správne je „stodvadsaťtri celých štyridsaťpäť stotín“ (prevod typu „celá, desatina“).

Vkladanie čísiel slovami v OpenOffice.org Calc

Po nainštalovaní rozšírenia sa do prostredia OpenOffice.org Calc pridá do menu Nástroje | Prídavky položka JP SK/CS číslo na slovo, ktorá obsahuje dve voľby: Inicializácia funkcie NUMBERTOTEXT a Vymazanie knižníc verzie nižšej ako 2010.08.30 (kompatibilita). Skôr, ako budete môcť používať rozšírenie v module OpenOffice.org Calc musíte spustiť prvú voľbu Inicializácia funkcie NUMBERTOTEXT. Pravdaže, stačí, ak toto urobíte jedenkrát, najlepšie ihneď po nainštalovaní rozšírenia.

Druhá voľba je určená pre tých používateľov, ktorí používali staršie verzie tohto rozšírenia, ktoré boli k dispozícii na portáli 602Office.cz – pomocou nej odstránia staré knižnice, ktoré by inak viedli ku kolízii (rovnaké názvy funkcií). Zároveň je potrebné, aby ešte pred inštaláciou novej verzie odinštalovali starú verziu tohto rozšírenia.

Po inicializácii pribudli v OpenOffice.org Calc nové funkcie NUMBERSKTEXT, NUMBERCSTEXT, NUMBERTOTEXT a pre zachovanie kompatibility so staršími verziami tohto rozšírenia aj funkcie SLOVOMSK a SLOVEMCZ. Funkcie môžete vkladať priamo do buniek v zošitoch ako ktorékoľvek iné funkcie OpenOffice.org Calc.

Funkcie NUMBERSKTEXT, NUMBERCSTEXT

Parametre:

  • Číslo – povinný parameter, ktorý obsahuje prevádzané číslo, môže byť zadané aj ako reťazec, aj ako číslo

  • Typ – nepovinný parameter, ktorý určuje typ prevodu:

    • 0 – číslo sa prevedie ako celé (prednastavená hodnota)
    • 1 – číslo sa prevedie ako reálne
    • 2 – číslo sa prevedie ako reálne, desatinná časť sa prevedie v tvare xx/100
    • 3 – prevedie sa iba desatinná časť
    • 4 (a viac) – prevedie sa iba desatinná časť v tvare xx/100
  • Písmeno – nepovinný parameter, ktorý určuje veľkosť prvého písmena:

    • 0 – prvé písmeno malé (prednastavená hodnota)
    • 1 (a viac) – prvé písmeno veľké
  • Spolu – nepovinný parameter, ktorý určuje medzery a finančné čísla:

    • 0 – s medzerami (prednastavená hodnota)
    • 1 – bez medzier
    • 2 – finančné číslo s medzerami
    • 3 (a viac) – finančné číslo bez medzier
  • Mena – nepovinný parameter, ktorý určuje typ meny

    • 0 – bez meny (prednastavená hodnota)
    • 1 – typ „celých, desatín“
    • 2 – typ „euro, centy“
    • 3 – (a viac) – typ „koruny, haliere“
  • Desatinné – nepovinný parameter, ktorý určuje počet desatinných miest výsledku. Pozor, výsledok sa nezaokrúhľuje, ale použije sa príslušný počet desatinných miest. Prednastavená hodnota určuje, že sa použije taký počet desatinných miest, aký je zadaný.

Ako to vyplýva už z názvov funkcií, funkcia NUMBERSKTEXT prevádza číslo na slovenský text a funkcia NUMBERCSTEXT na český. Pravdaže, nie všetky kombinácie parametrov majú význam – napríklad pri prevode desatinnej časti na tvar xx/100 sa nepoužijú názvy desatín, centov či halierov, a pokiaľ sa prevádza na takýto tvar iba desatinná časť, potom nemajú význam žiadne ďalšie parametre okrem počtu desatinných miest.

Ukážka použitia funkcií NUMBERSKTEXT a NUMBERCSTEXTUkážka použitia funkcií NUMBERSKTEXT a NUMBERCSTEXT

Príklady použitia:

  • =NUMBERSKTEXT(123456,789;1;1;1;1) – Stodvadsaťtritisícštyristopäťdesiatšesť celých Sedemstoosemdesiatdeväť tisícin
  • =NUMBERSKTEXT(123456,789;1;0;0;0;2) – stodvadsaťtritisíc štyristopäťdesiatšesť
  • =NUMBERSKTEXT(123456,789;1;1;1;1;2) – Stodvadsaťtritisícštyristopäťdesiatšesť celých Sedemdesiatosem stotín
  • =NUMBERSKTEXT(123456,789;1;0;2;2;2) – jednostodvadsaťtritisíc štyristopäťdesiatšesť eur sedemdesiatosem centov
  • =NUMBERSKTEXT(123456,789;1;1;4;3;2) – Jednostodvadsaťtritisícštyristopäťdesiatšesť korún Sedemdesiatosem halierov
  • =NUMBERCSTEXT(123456,789;1;0;1;1) – stodvacettřitisícčtyřistapadesátšest celých sedmsetosmdesátdevěť tisícin
  • =NUMBERCSTEXT(123456,7891;1;0;0;2) – Sto dvacet tři tisíc čtyři sta padesát šest
  • =NUMBERCSTEXT(123456,789;2;0;1;1;2) – stodvacettřitisícčtyřistapadesátšest celých 78/100
  • =NUMBERCSTEXT(123456,789;3;1;2;2;2) – Sedmdesát osm centů
  • =NUMBERCSTEXT(123456,789;4;0;4;3;2) – 78/100

Funkcia NUMBERTOTEXT

Parametre:

  • Jazyk – povinný parameter, ktorý obsahuje reťazec určujúci jazyk, na ktorý sa má previesť číslo. Môže nadobúdať dve hodnoty „sk“ alebo „cs“ (veľkosť písmen je ignorovaná), pri ostatných vracia prázdny reťazec.
  • Číslo, Typ, Písmeno, Spolu, Mena, Desatinné – tieto parametre sú zhodné s parametrami funkcií NUMBERSKTEXT a NUMBERCSTEXT, a preto sa nimi už nemusíme zapodievať.

Príklady použitia:

  • =NUMBERTOTEXT("sk";5678,01;1;1;0;1) – Päťtisíc šesťstosedemdesiatosem celých Jedna stotina
  • =NUMBERTOTEXT("CS";5678,01;1;1;0;1) – Pět tisíc šest set sedmdesát osm celých Jedna setina

Funkcie SLOVOMSK a SLOVEMCZ

Tieto funkcie sú vložené do rozšírenia z dôvodu zachovania kompatibility s predchádzajúcimi verziami, ktoré obsahovali iba tieto dve funkcie. Parametre:

  • Číslo – povinný parameter, ktorý obsahuje prevádzané číslo, môže byť zadané aj ako reťazec, aj ako číslo.
  • Finančné – nepovinný logický parameter, ktorý určuje, či sa číslo bude alebo nebude písať ako finančné. Prednastavená hodnota je, že sa vkladá finančné číslo.
  • Veľké – nepovinný logický parameter, ktorý určuje, či sa číslo bude vkladať s prvým písmenom veľkým. Prednastavená hodnota je, že sa vkladá s veľkým písmenom.

Ukážka použitia funkcií SLOVOMSK a SLOVEMCZUkážka použitia funkcií SLOVOMSK a SLOVEMCZ

Tieto funkcie prevádzajú na slovo (SLOVOMSK slovensky a SLOVEMCZ česky) iba celú časť čísla (môže však byť zadané aj s desatinnou časťou), a to nasledujúcimi štyrmi kombináciami:

  • =SLOVOMSK(123456;"TRUE";"TRUE") – Jednostodvadsaťtritisícštyristopäťdesiatšesť
  • =SLOVOMSK(123456;"FALSE";"TRUE") – Stodvadsaťtritisíc štyristopäťdesiatšesť
  • =SLOVEMCZ(123456;"TRUE";"FALSE") – jednostodvacettřitisícčtyřistapadesátšest
  • =SLOVEMCZ(123456;"FALSE";"FALSE") – sto dvacet tři tisíc čtyři sta padesát šest

stahnout.png

(Jako ve škole) Průměr: 4,00 | Hodnotilo: 21
 

Komentáře

user avatar Jaroslav
Odpovědět
Rozšírenie pre vkladanie čísla slovom
21. 09. 2010, 07:31:31
Dobrý den,
chtěl bych upozornit, že v pokladních dokladech, na které upozorňujete v úvodu článku, probíhá převod ve formě "halíř" ale správně je "haléř".
http://cs.wikipedia.org/wiki/Haléř
user avatar j-pastierik
Odpovědět
Re:Rozšírenie pre vkladanie čísla slovom
21. 09. 2010, 09:15:14
Ďakujem za informáciu. V tomto smere som sa pred zverejnením informoval a dostal som ako odpoveď vyskloňované slovo "halíř". Aj na Vami uvedenom odkaze je napísané: "Haléř či halíř", takže som toto nevedel správne posúdiť. Vzhľadom na to, že na stránkach ČNB sa píše "haléř", opravím v tomto smere spomínané doklady aj rozšírenie pre vkladanie čísla slovom a napíšem o tom krátku správu.
user avatar L Štěpán
Odpovědět
Re:Re:Rozšírenie pre vkladanie čísla slovom
8. 10. 2010, 19:00:27
Užitečné a šikovné, vše v pořádku až na toto:
devěť set devadesát devěť korun devadesát devěť haléřů.
Háček v češtině ve slově devět se nepíše. Jinak díky a
více takových pomocníčků. LŠ
user avatar j-pastierik
Odpovědět
Re:Re:Re:Rozšírenie pre vkladanie čísla slovom
8. 10. 2010, 20:15:44
Ďakujem, chybu som opravil a nová verzia je už k dispozícii na stiahnutie - http://www.openoffice.cz/novinky/oprava-chyby-v-rozsireni-pre-vkladanie-cisla-slovom.
user avatar j-pastierik
Odpovědět
Re:Rozšírenie pre vkladanie čísla slovom
21. 09. 2010, 10:10:24
http://www.openoffice.cz/novinky/nova-verzia-rozsirenia-pre-vkladanie-cisla-slovom

Ešte raz ďakujem.
user avatar Jaroslav
Odpovědět
Re:Re:Rozšírenie pre vkladanie čísla slovom
21. 09. 2010, 10:44:42
OpenOffice jsem si oblíbil, takže když můžu rád pomůžu. Hezký den
user avatar student
Odpovědět
dá sa to použiť automaticky?
29. 09. 2010, 11:32:46
Potreboval by som to použiť nasledovne:
Mám vytvorený šablónu vo Write - "formulár" s poliami, do ktorých sa dáta vypĺňajú z databázy vytvorenej v Base až keď sa tlačia (občajne hromadá tlač).
Keď som to dobre pochopil, toto rozšírenie potrebuje interakciu užívateľa. Nedá sa to aplikovať ako "vzorec", tak aby to previedlo číslo ,ktoré sa vyplňuje v rámci poľa, na text? V Calc to tak funguje, ale ja by som to potreboval vo Write.
ďakujem za nápad.
user avatar j-pastierik
Odpovědět
Re:dá sa to použiť automaticky?
29. 09. 2010, 17:17:04
Tak (iné použitie zatiaľ neviem), že si tam skopírujete tabuľku z Calcu (ako OLE objekt), kde bude vložená funkcia pre vkladanie čísla slovom. Týmto sa to stane súčasťou dokumentu vo Writeri (nebude to záležať na tabuľke, odkiaľ si to skopírujete) a pri zmene čísla sa zmení aj text. Žiaľ, je to dosť obmedzené čo sa týka formátovania.
user avatar barny
Odpovědět
Re:dá sa to použiť automaticky?
8. 11. 2010, 18:14:42
Tak si vytvoř v CALCu pole s touto funkcí a až teprve výsledek tohoto pole vlož do formuláře WRITERu.
user avatar Tono
Odpovědět
Rozšírenie pre vkladanie čísla slovom
25. 02. 2011, 20:12:55
Nainštaloval som si rozšírenie vo Writeri to funguje avšak v Calcu sa funkcie ani po inicializácii neobjavili. Čo som spravil zle?
user avatar j-pastierik
Odpovědět
Re:Rozšírenie pre vkladanie čísla slovom
26. 02. 2011, 07:19:11
Skúste povedzme do bunky B2 vložiť =NUMBERSKTEXT(A1) - fun guje? Inak funkcie nie sú uvedené v žiadnom zozname.
user avatar Petr Lysák
Odpovědět
Rozšírenie pre vkladanie čísla slovom
18. 04. 2011, 12:38:17
Stejný problém jako tono, funkce se neobjeví v seznamu, dle vysvětleni níže od pana Pastierika funkci lze pouzit, to potvrzuji. Chtěl bych se zeptat na související věc. Po instalaci rozšíření (převodu na text) se v panelu nástrojů objevilo meníčko k funkci NUMBERSKTEXT a NUMBERCSTEXT. Po dalším zapnutí Calcu meníčko již v panelu není a nevím přesně jak se k němu dostat. Může mi někdo poradit? Díky.
user avatar Jarda
Odpovědět
Chybka: Rozšírenie pre vkladanie čísla slovom
25. 10. 2011, 19:23:17
Trochu pozdě, ale přece.
Nainstaloval jsem v Calcu a objevil jsem následující chybu:
Pokud se zadá reálné číslo např. 4,3 a použije funkce =NUMBERSKTEXT(A4;1;0;0;2), dostaneme text
"tri eurá dva centy" (nebo "tři eura dva centy"). V případě, že se převádí číslo s měnou, je třeba vyřešit část za desetinnou čárkou a správně vypsat (v tomto případě) třicet centů atp.
Jinak fce jsou to užitečné, díky.
user avatar j-pastierik
Odpovědět
Re:Chybka: Rozšírenie pre vkladanie čísla slovom
26. 10. 2011, 07:25:32
Musíte zadať na vstupe reťazec "4,30" a potom bude prevod urobený správne. Funkcie pre prevod (NUMBERSKTEXT, ...) umožňujú ako prevod čísla zadaného ako číslo, tak aj čísla zadaného ako reťazec. Skúste použiť =NUMBERSKTEXT(TEXT(A4;"0,00");1;0;0;2) a dostanete správne textové znenie.

Nabudúce, prosím, napíšte do diskusného fóra, pretože dikusiu pri starších článkoch už sleduje málokto a odpoveď môže zaujímať viacerých.
user avatar Pavel
Odpovědět
Rozšírenie pre vkladanie čísla slovom
17. 11. 2011, 15:02:59
Nainstaloval jsem doplněk a zjistil jsem ze pro např. 2500 (podobne pro 3000 a 4000)
dáva "dvatisícpětset" místo "dvatisícepětset".
user avatar j-pastierik
Odpovědět
Re:Rozšírenie pre vkladanie čísla slovom
18. 11. 2011, 06:48:21
Bola tam chyba (zostal riadok z testovania), ďakujem. Novú verziu rozšírenia dnes (18.11.2011) zverejním.
user avatar Robo
Odpovědět
Rozšírenie pre vkladanie čísla slovom
23. 08. 2013, 10:33:04
Dobry den,
pouzivame s kolegom W7 + LO 4.1. Mne sa podarilo nainstalovat rozsirenie bez problemov a funguje. Kolegovi instalacia neprebehne a vypisuje mu nasledovne hlasenie:
Rozsirenie nemoze byt nainstalovane, lebo nie su splnene nasledovne zavislosti - rozsirenie vyzaduje OO aspon vo verzii 4.0
Neviete mi prosim poradit kde by mohla byt chyba, resp. ako toto hlasenie obist? (okrem toho ze je potrebne nainstalovat OO)
Dakujem
user avatar j-pastierik
Odpovědět
Re:Rozšírenie pre vkladanie čísla slovom
26. 08. 2013, 05:46:19
http://www.openoffice.cz/novinky/nove-verzie-rozsireni-pre-openoffice-4-0
user avatar Robo
Odpovědět
Rozšírenie pre vkladanie čísla slovom
2. 09. 2013, 09:55:35
Dakujem za info. Pomohlo pouzitie starsej verzie

Přidat názor

 

Nejsou podporovány žádné značky, komentáře jsou jen čistě textové. Více o diskuzích najdete v nápovědě. Diskuzi můžete sledovat pomocí RSS kanálu.

 
Július Pastierik

Július Pastierik

 
 
 
woo jaw demo hz