poniedziałek, 29 października 2007

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.

12 komentarze:

Maciek 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

Marcin 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 ..."