# How to format a numeric field in Crystal to print an integer or a decimal depending on the value.

What would be the appropriate way to format a numeric field so that it will not print any zeros to the right of the decimal point.

8.00 would print as 8
1.40 would print as 1.4
1.36 would print as 1.36
###### Who is Participating?

Commented:
You can also control it through the format

Right click the field
Click FORMAT FIELD
Click the NUMBER TAB
Click CUSTOMIZE
CLick the formula button to the right of DECIMALS

if Int ({field}) = {field} then
0
else  if (Int({field} * 10) = {field} * 10 then
1
else
2

mlmcc
0

Commented:
Do you only need 0, 1, or 2 decimals?

mlmcc
0

IT ManagerAuthor Commented:
I need all 3 if the number goes out that far. So, If I set the field to have 2 decimals, and the value returned on the report is 8.00 - how can I get that to report as 8. How can I get 1.40 to print as 1.4?

I want it to drop any zeros to the right of the decimal point and remove the decimal and print as an integer if it is a whole number.
0

Commented:
You don't ned to go to 3 decimals ever? Say 1.125?

mlmcc
0

Commented:
Assuming that you never want to see more than 2 decimal places, you could create a formula similar to the following and put it on the report:

if Int ({field}) = {field} then
CStr ({field}, 0)
else
if ({field} * 100) \ 10 = {field} * 10 then
CStr ({field}, 1)
else
CStr ({field}, 2)

That seems to work.  It converts the number to a string, using different numbers of decimal places, based on the value.  FYI, the backwards slash (\) is integer division in CR.

One basic limitation with that approach is that you won't be able to do summaries on that report field, because it's a string, but if you need a summary, you can just put the actual field on the report too, but suppressed, and then summarize that.

FWIW, there are several other ways that you could handle those decimals.  That's just one option.

James
0

Commented:
I think you've got an extra "(",  or left out a ")".

else  if Int({field} * 10) = {field} * 10 then

James
0

Commented:
You're right

if Int ({field}) = {field} then
0
else  if  Int({field} * 10) = {field} * 10 then
1
else
2
0

IT ManagerAuthor Commented:
Wonderful. This works. Thank you for the formula mlmcc and the correct James.
0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.