Keď som pred pár týždňami robil kalkulačku, ktorá podporuje prevody medzi číselnými sústavami bol som velmi prekvapený, keď som vo Visual Basicu nenašiel skoro žiadne funkcie na tieto prevody. Jedinú funkciu čo som našiel je funkcia Hex. Táto funkcia slúži na prevod z desiatkovej do šestnástkovej (hexadecimálnej) sústavy. Kedže som potreboval aj iné funkcie, tak mi neostávalo nič iné, ako naprogramovať si ich. Rozhodol som sa napísať ich tu, lebo sa môžu hodiť každému programátorovi...
Ako som už spomínal, na prevedenie z desiatkovej do hexadecimálnej slúži príkaz Hex. Pri prevedení z binárnej do hexadecimálnej treba najskôr previesť číslo do desiatkovej a až potom do hexadecimálnej. Funkcie na prevedenie do osmičkovej sústavy som sem nenapísal, lebo táto sústava sa velmi nepoužíva. Ale ak by mal niekto záujem tak mu ich môžem poslať.
Z desiatkovej do binárnej sústavy:
Function DecBin(Cislo As Long) As String
Dim i As Integer
While Cislo <> 0
DecBin = Cislo Mod 2 & DecBin
If Cislo Mod 2 = 0 Then
Cislo = Cislo / 2
Else
Cislo = (Cislo - 1) / 2
End If
Wend
End Function
Msgbox DecBin(25)
Z binárnej do desiatkovej sústavy:
Function BinDec(Cislo As String) As Long
Dim i As Integer
Dim X as Long
For i = 0 To Len(Cislo) - 1
If Right(Cislo, 1) = "0" Then X = X + 0 * 2 ^ i
If Right(Cislo, 1) = "1" Then X = X + 1 * 2 ^ i
Cislo = Left(Cislo, Len(Cislo) - 1)
Next i
BinDec = X
End Function
MsgBox BinDec(10011)
Z hexadecimálnej do desiatkovej:
Function HexDec(Cislo As String) As Long
Dim i As Integer
Dim X as Long
Cislo = LCase(Cislo)
For i = 0 To Len(Cislo) - 1
If Right(Cislo, 1) = "a" Then X = X + 10 * 16 ^ i
If Right(Cislo, 1) = "b" Then X = X + 11 * 16 ^ i
If Right(Cislo, 1) = "c" Then X = X + 12 * 16 ^ i
If Right(Cislo, 1) = "d" Then X = X + 13 * 16 ^ i
If Right(Cislo, 1) = "e" Then X = X + 14 * 16 ^ i
If Right(Cislo, 1) = "f" Then X = X + 15 * 16 ^ i
If Right(Cislo, 1) < 10 Then X = X + Right(Cislo, 1) * 16 ^ i
Cislo = Left(Cislo, Len(Cislo) - 1)
Next i
HexDec = X
End Function
Msgbox HexDec("4f2b")