Przejdź do głównej zawartości

Słownie złotych

Czasami na raportach, na przykład na fakturach, zachodzi potrzeba zamiany liczby na słownie złotych. Crystal to umożliwia ale tylko na język ang.

Dlatego napisałem funkcję UFL do CR, która to realizuje.

Jest to funkcja typu Crystal Reports UFL (User Function Libraries) i korzysta sie z niej tak samo jak z wbudowanych funkcji Crystal Reports.

Obecny zakres liczb od 0 do biliona.

Opis instalacji

0. Pobierz

1. Rozpakować archiwum i skopiować plik CRUFLslw.dll do np. katalogu C:\WINDOWS\system32

2. Uruchomić linię poleceń: CMD

3. Przejść do katalogu z plikiem: CD C:\WINDOWS\system32

3. Uruchomić polecenie rejestracji biblioteki: regsvr32 CRUFLslw.dll

Powinno wyświetlić się okno z informacją "DllRegisterServer in CRUFLslw.dll succeeded."

4. Uruchomić Crystal Reports

5. Utworzyć nową formułę i wpisać np. slownie(123.45)

Przetestowałem również z Crystal Reports 2008 i działa.

Komentarze

Anonimowy pisze…
Wielkie dzięki, a już zabierałem sie do tworzenia mega funkcji IF co by przetlumaczyc angielski na polski. Biblioteka baaaaaardzo sie przyda, pozdrawiam serdecznie
Unknown pisze…
Super!!! Funkcja działa też na starym Crystal Reports 8.5...wielkie dzięki...ratuje mi skórę :)
Tomek pisze…
Mam Pytanie a czy jest możliwość żeby ta funkcja zwracała wartość słownie jakiegoś pola danych? przykładowo sumy kilku składników?z góry dziękuje za pomoc
Marcin Sulecki pisze…
Oczywiście. Można utworzyć formułę, która będzie sumą składników i podstawić ją jako argument do funkcji np. slownie(@suma)
Tomek pisze…
Witam jeszcze raz:)Przepraszam że tak męczę ale gdy wpisuję formułę slownie({@KwPoz}), pokazuje mi się błąd "A number is required here" Pozdrawiam
Marcin Sulecki pisze…
Funkcja slownie oczekuje liczby jako argumentu. Upewnij się, czy formuła @KwPoz jest liczbą.
tomgryg pisze…
Witam,
a czy tę bibliotekę wystarczy wgrać na lokalnym komputerze czy również trzeba na serwerze raportowym?
Marcin Sulecki pisze…
Funkcja musi być zainstalowana tam gdzie jest generowany raport. Jeśli po stronie serwera, to musi być na serwerze.
Marcin Sulecki pisze…
CR 2008 posiada wbudowaną funkcję do konwersji liczby na język polski.

Sposób jej użycia opisałem w nowym
artykule
Anonimowy pisze…
A jedno pytanko którego tu nie zadano .... Jeśli wykorzystam tę bibliotekę w raporcie komercyjnym dla klienta to na jakiej zasadzie jest udzielana licencja ? Nie cierpię piractwa ...
Anonimowy pisze…
Na komputerze, gdzie zainstalowany jest CR 8.5 sp3 raport Subiekta GT działa bardzo ładnie podając wynik funkcji slownie(123). Jednak, gdy taki raport .rpt importuje do innego komputera, gdzie nie ma zainstalowanego CR raport nie działa. Po uruchomieniu raportu wyrzuca błąd: "The remaining text does not appear to be part of the formula". Oczywiście biblioteka CRUFLslw.dll rejestruje się bez problemu na obu komputerach. Nie pomaga restart komputera. Gdy z raportu usuwam pole w którym jest procedura slownie(123) wszystko jest ok. Czy ktoś orientuje się co jest przyczyną tego problemu ?
Anonimowy pisze…
Mógłbym prosić o ustosunkowanie się do pytania Kolegi ??

"A jedno pytanko którego tu nie zadano .... Jeśli wykorzystam tę bibliotekę w raporcie komercyjnym dla klienta to na jakiej zasadzie jest udzielana licencja ? Nie cierpię piractwa ..."
Anonimowy pisze…
Witam, można prosić o paczkę gdyż link wygasł a przydałby mi sie skrypcik :)
Marcin pisze…
W związku z wieloma zapytania chciałem poinformować, że biblioteka słownie złotych do zastosowań komercyjnych nie jest darmowa. Jeśli ktoś jej zainteresowany ofertą to proszę o maila.
Marcin pisze…
W przypadku systemu 64-bitowego bibliotekę należy zarejestrować poleceniem:

cd \windows\syswow64
regsvr32 C:\windows\System32\CRUFLSLW.DLL

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ż

Funkcje Crystal Reports

Crystal Reports posiada bardzo dużo funkcji (ok. 200) do operacji na tekstach, liczbach, datach itd. Można się z nimi zapoznać przeglądając drzewo Funkcje (Functions) w Edytorze Formuł (Formula Editor) i czytając helpa. Warto je znać, aby nie wyważać otwartych drzwi.  Problem w tym, że trzeba wiedzieć czego się szuka.   Dla wielu osób dodatkową barierą może być język angielski, bo nawet w polskiej wersji Crystala, help, o przepraszam.... pomoc jest w języku Szekspira. Dlatego stworzyłem niegdyś listę funkcji Crystal Reports w języku polskim, którą otrzymywali uczestnicy moich szkoleń w formacie PDF.  Teraz postanowiłem  opublikować ją w sieci, aby była zawsze była pod ręką i dostępna dla szerszego grona.  Lista funkcja dostępna jest tutaj . Lista funkcji nie jest jeszcze w pełni kompletna, więc będę ją na bieżąco aktualizować. Czekam na wasze komentarze i uwagi, zwłaszcza propozycje lepszych tłumaczeń. Miłego korzystania!