Vítejte na Elektro Bastlírn?
Nuke - Elektro Bastlirna
  Vytvořit účet Hlavní · Fórum · DDump · Profil · Zprávy · Hledat na fóru · Příspěvky na provoz EB

Vlákno na téma KORONAVIRUS - nutná registrace


Nuke - Elektro Bastlirna: Diskuzní fórum

 FAQFAQ   HledatHledat   Uživatelské skupinyUživatelské skupiny   ProfilProfil   Soukromé zprávySoukromé zprávy   PřihlášeníPřihlášení 

Office 365
Jdi na stránku Předchozí  1, 2, 3, 4
 
Přidat nové téma   Zaslat odpověď       Obsah fóra Diskuzní fórum Elektro Bastlírny -> Software
Zobrazit předchozí téma :: Zobrazit následující téma  
Autor Zpráva
Bernard



Založen: May 27, 2005
Příspěvky: 3655

PříspěvekZaslal: čt září 11 2025, 15:01    Předmět: Citovat

Možná to není problém jen v zaokrouhlení, ale v interpretaci té funkce:
kód:
CHOOSE(B10+1;"nula";"jedna";"dva";"tri";"štyri";"päť";"šesť";"sedem";"osem";"deväť")

V Helpu se dočteme, že první argument je index, který se vyhodnotí jako INT, takže INT(B10+1) = INT(5,99... + 1) = 6;
Z dalších argumentů se vybírá tak, že první na řadě je ten s indexem 1, tedy ten "nula". Šestý v pořadí je potom argument "päť".
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu
PotPalo



Založen: May 13, 2009
Příspěvky: 5720
Bydliště: BA-Petržalka :(

PříspěvekZaslal: čt září 11 2025, 17:42    Předmět: Citovat

Funkcia je správna, podľa celého čísla dá text. Akurát to celé číslo nieje celé, lebo excel. Malo vyjsť celé číslo 6, nie 5,99....

Aj som to vtedy dávno riešil zaokrúhľovaním, aj keď z matematického hľadiska to bol nezmysel zaokrúhľovať celé číslo.

_________________
Globálne otepľovanie je spôsobené masívnou zástavbou a rúbaním storočných stromov. Kamene namiesto trávy tiež prispievajú k otepľovaniu.
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu Odeslat e-mail
martinkopp



Založen: Oct 12, 2023
Příspěvky: 952

PříspěvekZaslal: čt září 11 2025, 19:43    Předmět: Citovat

Pokud je to číslo výsledkem nějakých předchozích operací a máš formát floatu, tak tam většinou nějaký ocásek bude. Ty prostě nechápeš systém ukládání desetinných čísel v počítači a systém práce s nima. Tohle není jen záležitost excelu, ale všech běžných tabulkových procesorů.

Pro pochopení ti dám příklad, chceš použít nějakou podmínku na čísla 0,33 a (0,3+0,03). Logikou sekretářky by měly být obě čísla stejné, ale:

0,33 je ve 64bitovém floatu uloženo jako 0,33000000000000001554312234475219116318225860595703125

0,3 je uloženo jako 0,299999999999999988897769753748434595763683319091796875

0,03 je uloženo jako 0,03000000000000000277555756156289135105907917022705078125

takže když sečteš 0,3+0,03 dostaneš 0,32999999999999999167332731531132594682276248931884765625

Pro standartní výpočty to není žádný problém, ale pro funkce typu IF už ano, protože jsou to dvě odlišná čísla. Když provedeš zaokrouhlení, uděláš z 0,32999999999999999167332731531132594682276248931884765625 opět 0,33000000000000001554312234475219116318225860595703125 a pak už ti IF aspol. fungovat bude, protože to sice nikdy nebude přesně 0,33, ale obě čísla budou stejné. Pokud nepochopíš věci jako tohle, je lepší se do takových funkcí raději nepouštět.

Takže pro funkce typu CHOOSE, SWITCH, IF... si to musíš zaokrouhlit. Tak to prostě je, bylo, a vždy bude. Nebo si nastav v Soubor → Možnosti → Upřesnit → Při výpočtech v sešitu → Nastavit přesnost podle zobrazení. Pak se bude počítat jen s tím co vidíš v buňkách, ale přijdeš o přesnost.

edit: tak excel prý nedokáže používat jiný datový typ než float, takže použití např. integer tvůj problém neřeší. Osobně používám z ms office access, přijde mi efektivnější a jednodušší a tam je možné použít i jiné datové typy než 64bi float. Takže v excelu se nevyznám, ale tak nějak to v každém případě bude, když tak ať někdo opraví nepřesnosti v uvedených tvrzeních.


Naposledy upravil martinkopp dne čt září 11 2025, 19:50, celkově upraveno 1 krát.
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu
PotPalo



Založen: May 13, 2009
Příspěvky: 5720
Bydliště: BA-Petržalka :(

PříspěvekZaslal: čt září 11 2025, 19:49    Předmět: Citovat

Nastaviť presnosť podľa zobrazenia som skúšal a nefungovalo to.

Niečo čo počíta na 16 desatinných miest, ale blbo, je aj tak k hovnu.

_________________
Globálne otepľovanie je spôsobené masívnou zástavbou a rúbaním storočných stromov. Kamene namiesto trávy tiež prispievajú k otepľovaniu.
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu Odeslat e-mail
martinkopp



Založen: Oct 12, 2023
Příspěvky: 952

PříspěvekZaslal: čt září 11 2025, 20:00    Předmět: Citovat

Zmíněné nastaveni funguje tak nějak všelijak, aplikuje se jen na nově přidané (změněné) buňky po jeho přepnutí apod. Jistější je používat to zaokrouhlení, to bude fungovat vždy.

To že jsi objevil záludnosti používání floatu až dnes je sice hezké, ale fungovat tak bude naprosto všechno v čem bys chtěl podobné věci dělat. Není to nějaká specialita excelu. Jede na tom s nadsázkou celý svět a když se s tím naučíš pracovat, žádný problém to není. Jinou volbu stejně prostě nemáš Smile
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu
PotPalo



Založen: May 13, 2009
Příspěvky: 5720
Bydliště: BA-Petržalka :(

PříspěvekZaslal: čt září 11 2025, 20:41    Předmět: Citovat

Takže svet je definitívne v prdeli. Nevadí. Twisted Evil
_________________
Globálne otepľovanie je spôsobené masívnou zástavbou a rúbaním storočných stromov. Kamene namiesto trávy tiež prispievajú k otepľovaniu.
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu Odeslat e-mail
martinkopp



Založen: Oct 12, 2023
Příspěvky: 952

PříspěvekZaslal: čt září 11 2025, 20:48    Předmět: Citovat

No, float se používá v excelu (a všem podobném) někdy od 80 let minulého století. Takže svět je definitivně v prdeli už 40let, jen ty sis toho všiml až dnes Smile
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu
Zobrazit příspěvky z předchozích:   
Přidat nové téma   Zaslat odpověď       Obsah fóra Diskuzní fórum Elektro Bastlírny -> Software Časy uváděny v GMT + 1 hodina
Jdi na stránku Předchozí  1, 2, 3, 4
Strana 4 z 4

 
Přejdi na:  
Nemůžete odesílat nové téma do tohoto fóra.
Nemůžete odpovídat na témata v tomto fóru.
Nemůžete upravovat své příspěvky v tomto fóru.
Nemůžete mazat své příspěvky v tomto fóru.
Nemůžete hlasovat v tomto fóru.
Nemůžete připojovat soubory k příspěvkům
Můžete stahovat a prohlížet přiložené soubory

Powered by phpBB © 2001, 2005 phpBB Group
Forums ©
Nuke - Elektro Bastlirna

Informace na portálu Elektro bastlírny jsou prezentovány za účelem vzdělání čtenářů a rozšíření zájmu o elektroniku. Autoři článků na serveru neberou žádnou zodpovědnost za škody vzniklé těmito zapojeními. Rovněž neberou žádnou odpovědnost za případnou újmu na zdraví vzniklou úrazem elektrickým proudem. Autoři a správci těchto stránek nepřejímají záruku za správnost zveřejněných materiálů. Předkládané informace a zapojení jsou zveřejněny bez ohledu na případné patenty třetích osob. Nároky na odškodnění na základě změn, chyb nebo vynechání jsou zásadně vyloučeny. Všechny registrované nebo jiné obchodní známky zde použité jsou majetkem jejich vlastníků. Uvedením nejsou zpochybněna z toho vyplývající vlastnická práva. Použití konstrukcí v rozporu se zákonem je přísně zakázáno. Vzhledem k tomu, že původ předkládaných materiálů nelze žádným způsobem dohledat, nelze je použít pro komerční účely! Tento nekomerční server nemá z uvedených zapojení či konstrukcí žádný zisk. Nezodpovídáme za pravost předkládaných materiálů třetími osobami a jejich původ. V případě, že zjistíte porušení autorského práva či jiné nesrovnalosti, kontaktujte administrátory na diskuzním fóru EB.


PHP-Nuke Copyright © 2005 by Francisco Burzi. This is free software, and you may redistribute it under the GPL. PHP-Nuke comes with absolutely no warranty, for details, see the license.
Čas potřebný ke zpracování stránky 0.35 sekund