So I am stuck on a formula in Crystal trying to convert a string field to a number field. My issue is that the string field is not just numbers, it contains values that have letters at the end of the numbers, for example the field will have 123456 and 123456-WHT.

The report is exported to excel and they then do a vlookup to another excel file that already has the product code set as a number, yes they can convert the exported spreadsheet in excel, but I am trying to save them some steps.

When I write the formula in Crystal, I get an error, my formula is If isNumeric(field) then tonumber(field) else (field). It keeps telling me that it needs a number (like 0) after the else, I don't want a number after the else I want it to be the value (123456-WHT). so I tried adding toText after the else and before the field, and I get the same error.

So the end result that I am looking for is if the value in the string field is a number (123456) the field on the report shows the numbers as a number, but if the string field contains (123456-WHT) it displays 123456-WHT.

Hope this makes sense, any help would be awesome.

If all of your part numbers are consistent with a dash at the end of the number sequence, then you can use the following 2 formulas to get to the number sequence. I don't have Crystal loaded on my new PC, but I believe the commands are:

Mid(Field_Name, Starting_Position, Number_of_positions_from_Start)

Length(Field_Name, "-") ; this formula will locate the dash (-) in the part field.

You can combine the two into one statement: Mid(Field_name,1,(Length(Field_name,"-",-1)), This will find the location of the dash in the field, then subtract 1 from that location, so you will stop selecting the characters one position to the left of the dash.

## 6 Replies

Honestly it does not make any sense. I started attempting to write a formula to parse it out but you are returning the same things as the field so i don't get it.

Even if you did 2 formulas and only showed the "true" result for the opposing formulas, and stacked them right on top of each other so that it looked like the same field... it is still not going to transpose as different data types in the excel export and even such excel has its own brand of voodoo that allows for assigning "number" type to cells that are clearly not.

I think the reality is that on the export, excel will by default make it a general or text unless everything in the column except the header is a number.

If all of your part numbers are consistent with a dash at the end of the number sequence, then you can use the following 2 formulas to get to the number sequence. I don't have Crystal loaded on my new PC, but I believe the commands are:

Mid(Field_Name, Starting_Position, Number_of_positions_from_Start)

Length(Field_Name, "-") ; this formula will locate the dash (-) in the part field.

You can combine the two into one statement: Mid(Field_name,1,(Length(Field_name,"-",-1)), This will find the location of the dash in the field, then subtract 1 from that location, so you will stop selecting the characters one position to the left of the dash.

That's the same approach i was taking glennowers but that's really not what he is looking for in the result. He still wants to display in the same way, but thinks Crystal will transpose it as different field types on the export and i disagree on that being possible. I spent about 37 minutes testing out a formula 9 different ways an then had the WTF moment... lmao.

Thanks damon.theis for the clarification. I re-read the question and agree with you.

You could use the Length formula to determine if a dash exists in the field. If it does not exist, the field must contain only numbers. If a dash does exist, you can use my formula to retrieve the numbers, then use the ToNumber function to convert the text to a number. This assumes you are consistent with the dash and the characters before the dash are your raw part number. If either is not true, then you will need to export to Excel and perform a VLOOKUP to determine the raw part number.

Thanks for the input, I will look at these options. Yes, the first 6 characters of the product code will always be numbers, then if the product comes in different colors, we add the dash and the color desc. So I think your solutions might just work. Thanks again for your input. damon.theis glennowers