Solved

# Scientific Number Conversions

Posted on 1998-07-27
447 Views
I need to convert a hex, octal, or binary number to DECIMAL.  How can I do this?  I know about the Hex and Oct functions, and can figure out decimal to binary, I just don't know how to get the number (string) back to decimal.  Also, if anyone has sample code for creating a scientific calculator (specifically the number conversions), I'd REALLY like to see it (and I'd pay extra points).
0
Question by:regent

Expert Comment

ID: 1466873
This is the source I use to convert a hex stored as a string to a decimal long. How it's done: I iterate through the HexNumber from left to right each place has a value of 16^(total length minus current position in strength) I multiply this value times the actual value of the place 0-15. Add up the values and return the sum.

Lonnie Brooke

Public Function HexToDecimal(HexNumber As String) As Long
Dim tmpAr() As Byte
Dim i&, j&, k&, t&, r&
Dim l\$, m\$

i = Len(HexNumber)
ReDim tmpAr(i) As Byte
j = 1
k = i - 1
While j < i + 1
t = Asc(Mid(HexNumber, j, 1))
Select Case t
Case 65 To 70
t = t - 55
Case 48 To 57
t = t - 48
End Select
r = r + ((16 ^ k) * t)
k = k - 1
j = j + 1
Wend

HexToDecimal = r

End Function

0

LVL 6

Accepted Solution

alamo earned 100 total points
ID: 1466874
The following function will convert a string representing a number in any base (2 through 36) to decimal. It handles illegal characters like Val(), by stopping the conversion.

Public Function ConvertToDecimal(sNumber As String, iBase As Integer) As Long
Dim lResult As Long
Dim i, iChar As Integer

For i = 1 To Len(sNumber)
iChar = Asc(UCase\$(Mid\$(sNumber, i, 1))) - 48
If iChar > 9 Then iChar = iChar - 7
If iChar < 0 Or iChar >= iBase Then Exit For 'invalid character
lResult = lResult * iBase + iChar
Next
ConvertToDecimal = lResult
End Function

Hope this helps!
0

## Featured Post

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

The debugging module of the VB 6 IDE can be accessed by way of the Debug menu item. That menu item can normally be found in the IDE's main menu line as shown in this picture.   There is also a companion Debug Toolbar that looks like the followin…
Have you ever wanted to restrict the users input in a textbox to numbers, and while doing that make sure that they can't 'cheat' by pasting in non-numeric text? Of course you can do that with code you write yourself but it's tedious and error-prone …
As developers, we are not limited to the functions provided by the VBA language. In addition, we can call the functions that are part of the Windows operating system. These functions are part of the Windows API (Application Programming Interface). U…
Get people started with the utilization of class modules. Class modules can be a powerful tool in Microsoft Access. They allow you to create self-contained objects that encapsulate functionality. They can easily hide the complexity of a process from…