Przejdź do głównej zawartości

Słownie złotych

Temat konwersji liczby na postać słowną wraca jak bumerang.

Warto wiedzieć, że w Crystal Reports jest wbudowana funkcja ToWords, która umożliwia konwersję liczby na postać słowną. Jednak w starszych wersjach (poniżej 2008) konwertowała ona liczby tylko do języka angielskiego.

Stąd ta funkcja była bezużyteczna dla polskiego użytkownika.
Dlatego niegdyś napisałem funkcję, która umożliwia konwersję liczby na język polski do pobrania tutaj.

Ale w wersji Crystal Reports 2008 wbudowana funkcja ToWords umożliwia konwersję na język polski! Bez potrzeby pisania skomplikowanych formuł lub stosowania dodatkowych bibliotek!

Jak to zrobić?

1. Wstawiamy do formuły funkcję ToWord({tabela.pole})
na razie skonwertuje nam na język angielski

2. Zmieniamy wyświetlany język na język polski:
Menu | View | Preffered Viewing Locale | More | Polish
(PL: Menu | Widok | Preferowane ustawienia regionalne wyświetlanie | Więcej | Polski)

I już możemy podziwiać napis "dziesięć tysięcy sto dwadzieścia trzy i 98 / 100"

Nie trzeba mieć do tego wersji polskiej CR, działa również w angielskiej.
Można również wybrać inny język, np. niemiecki, francuski a nawet japoński.

Świetna nauka języka :)

Komentarze

Unknown pisze…
A sprawdzałeś co się dziej dla kwoty z 0 groszy?
U mnie wyświetla prawidłową kwotę (część całkowitą) "i xx/100"?
I tak się dzieje dla każdej wartości całkowitej. Natomiast przy kwotach z groszami jest OK.
Marcin pisze…
Musisz wcześniej sprawdzić czy liczba jest całkowita i w razie czego usuwać fragment xx/100

Popularne posty z tego bloga

Konwersja daty w CDN Optima

Crystal Reports jest bardzo często zintegrowany z popularnymi aplikacjami. Przykładem jest system CDN Optima . Początkujących użytkownikom sprawiają kolumny z datą, bo data nie jest zapisana jako datetime lecz jako liczba. Otóż data w CDN Optima zapisana jest w formacie Clarion, czyli liczba dni, które upłynęły od daty 1800-12-28 . (Czy ktoś wie co to za data w historii?) Dlatego jeśli chcemy użyć takiego pola na raporcie, pierwsze co powinniśmy zrobić to dokonać konwersji liczby na datę. W innym przypadku Crystal Reports nie będzie wiedział, że jest to data i żadne formatowanie dat, grupowanie po okresach nie będzie działać. Formuła do konwersji formatu Clarion na datę : Jeśli mamy wiele takich pól to najlepiej utworzyć własną funkcję:

Zamiana daty i czasu na data-czas

Kolejne szkolenie u klienta i kolejne wyzwanie za mną... Chodziło o wygenerowanie raportu czasu pracy z uwzględnieniem, że zmiana następuje o godz. 6:00 a nie o północy. To znaczy, że godziny do 6:00 powinny być jeszcze zaliczane do dnia poprzedniego. Dodatkowym utrudnieniem u klienta był fakt, że data w bazie danych była rozbita na 2 pola: data w formacie: yyyy-mm-dd 00:00:00 godzina w formacie: 1900-01-01 HH:mm W takim razie do dzieła! Załóżmy, że mamy następującą tabelę: 1. Tworzymy formułę która zamieni 2 osobne pola z datą i czasem w jedno pole typu datetime: W ten sposób otrzymamy jedną wartość w formacie yyyy-mm-dd HH:mm 2. Następnie od tak utworzonej daty odejmujemy 6 godzin: Otrzymamy w rezultacie coś takiego: Kolumna WorkDate wyświetla datę do której została zakwalifikowana pozycja. Na podstawie tak utworzonej formuły można utworzyć grupowanie na raporcie.

Koszmar z limitem

Witajcie po dłuższej przerwie. Jakiś czas temu prowadziłem szkolenie w firmie i z jakiegoś powodu nie chciały nam się wyświetlać się wszystkie tabele z ich bazy danych. Na początku myślałem, że to kwestia uprawnień ale okazało się, że użytkownicy mają prawa do odczytu wszystkich tabel a problem wynika z czegoś innego... Okazało się, że winowajcą jest sam Crystal Reports, który ma ustawiony limit(!) na ilość obiektów pobieranych elementów ze struktury bazy danych, czyli tabel, widoków i procedur składowanych razem wziętych. Domyślnie jest to  8000 . Większość baz danych nie przekracza tego limitu, więc możecie spać spokojnie, ale przy większym systemie może nadejść koszmar, który zerwie Was na równe nogi. Pamiętajcie wówczas o moim blogu -  ten limit można zmienić (w praktyce podwyższyć). Niestety nie ma do tego opcji w Crystal Reports, trzeba pogrzebać w rejestrach windows: Zamykamy Crystal Reports Uruchamiamy aplikację Edytor rejestru , z linii poleceń: ...