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ę:

Jak używać SQL Expression?

SQL Expression to taka formuła, której treścią jest zapytanie SQL do bazy danych. Niestety, bezpośrednie wklejenie zapytania SQL kończy się najczęściej błędem "Error in compiling SQL Expression : Failed to retrieve data from the database" . Większość użytkowników w tym momencie kończy przygodę z SQL Expression, gdyż podręcznik użytkownika niewiele mówi na ich temat i nie przytacza żadnego przykładu. Rozwiązanie jest na wyciągnięcie ręki... Treść zapytania SQL musi być otoczone nawiasem! - to taki pomysł twórców Crystala. Zapytania musi zwracać wartość skalarną! - czyli musi zwracać pojedynczą wartość, a nie zestaw rekordów. Najczęściej jakąś funkcję agregującą np. sumę Oto przykład: Gotowe! Taką formułę można umieścić na raporcie lub wykorzystać do dalszego przetwarzania. To również bardzo dobry sposób na optymalizację raportu, zwłaszcza w przypadku gdy posiadamy w raporcie podraporty, które służą tylko pobieraniu pojedynczej wartości. Niestety trzeba znać chociaż

Wyświetlanie QRCode

Ostatnio coraz większą popularnością cieszą się tzw. foto-kody, czyli dwuwymiarowe kody kreskowe. Umożliwiają one przechowywanie zakodowanych informacji, które możemy odczytać za pomocą czytnika kodów kreskowych lub telefonem komórkowym dzięki specjalnej aplikacji. W fotokodzie może być zakodowany nie tylko tekst lecz adres URL, wizytówka vcard lub wiadomość sms. Jednym z najbardziej popularnych standardów jest QR Code . Crystal Reports nie posiada niestety wbudowanej obsługi kodów dwuwymiarowych.  Przedstawię wam prosty sposób na rozwiązanie tego problemu, bez potrzeby kupowania dodatkowych bibliotek. Otóż Crystal Reports umożliwia wstawienie obrazka graficznego spod wskazanego adresu url. Natomiast Google udostępnia usługę do generowania kodów kreskowych o nazwie Google Chart API . Musimy tylko przygotować odpowiedni url i w rezultacie otrzymamy obrazek graficzny w formacie PNG. Przykładowo, aby zakodować tekst Crystal Reports wystarczy wpisać do przeglądarki www taki adre