# Convert Dec to Binary - but Ones and Zeros

## Recommended Posts

Hi All,

Trying to convert a number to binary zeros and ones but I'm getting a result I don't understand and looks more like hex than binary.

Here's my basic code:

```\$myNum = 11
\$myNumBin = Binary(\$myNum)
MsgBox(0, "Binary result", \$myNumBin)```

What I want is "1011", what I get is 0x0B000000.

Thanks!

Edited by WoodGrain
Wrong syntax
##### Share on other sites

Try this:

```MsgBox(0, "", DecToBase(11, 2))

Func DecToBase(\$iInt, \$iBase) ; for bases 2 to 9
Local \$iRem, \$sRet = ''
While \$iInt > \$iBase -1
\$iRem = Mod(\$iInt, \$iBase)
\$sRet = \$iRem & \$sRet
\$iInt = Int((\$iInt - \$iRem) /\$iBase)
WEnd
Return \$iInt & \$sRet
EndFunc ;==> DecToBase```

To reverse the process you can use this:

```MsgBox(0, "", BaseToDec('1011', 2))

Func BaseToDec(\$sInt, \$iBase) ; bases 2 to 9 only
Local \$iRet = 0, \$iLen = StringLen(\$sInt)
For \$i = 1 To \$iLen
\$iRet += StringMid(\$sInt, \$i, 1) * \$iBase ^ (\$iLen - \$i)
Next
Return \$iRet
EndFunc ;==> BaseToDec```

Edited by czardas
##### Share on other sites

That worked perfectly, thanks!

I note it does bases 2 - 9, would it be complex to allow up to base 16 so I can convert it to hex as well?

##### Share on other sites

It's not so complicated, but unless you need bases 11 to 15, you might as well use Hex() and Dec(). I don't have much time this morning. You could try this old code of mine:
http://www.czardas.co.uk/repository/math10.au3

The code I posted in this thread can also be modified to convert larger numbers (up to Int64) by replacing the operators with operator64 functions (see my signature). Currently, these conversion functions only work for doubles ~ up to 15 decimal digits.

Edited by czardas
##### Share on other sites

No worries, thanks very much.

Actually, yeah, hex() works as expected

```\$myNum = 30
\$myNumHex = Hex(\$myNum, 2)
MsgBox(0, "Hex result", \$myNumHex)```

Returns 1E

Edited by WoodGrain
Update after testing
##### Share on other sites

18 hours ago, czardas said:

\$iInt = Int((\$iInt - \$iRem) /\$iBase)

This line could be written like this with no change in output.

`\$iInt = Int(\$iInt / \$iBase)`

If I posted any code, assume that code was written using the latest release version unless stated otherwise. Also, if it doesn't work on XP I can't help with that because I don't have access to XP, and I'm not going to.
Give a programmer the correct code and he can do his work for a day. Teach a programmer to debug and he can do his work for a lifetime - by Chirag Gude
How to ask questions the smart way!

I hereby grant any person the right to use any code I post, that I am the original author of, on the autoitscript.com forums, unless I've specifically stated otherwise in the code or the thread post. If you do use my code all I ask, as a courtesy, is to make note of where you got it from.

Back up and restore Windows user files _Array.au3 - Modified array functions that include support for 2D arrays.  -  ColorChooser - An add-on for SciTE that pops up a color dialog so you can select and paste a color code into a script.  -  Customizable Splashscreen GUI w/Progress Bar - Create a custom "splash screen" GUI with a progress bar and custom label.  -  _FileGetProperty - Retrieve the properties of a file  -  SciTE Toolbar - A toolbar demo for use with the SciTE editor  -  GUIRegisterMsg demo - Demo script to show how to use the Windows messages to interact with controls and your GUI.  -   Latin Square password generator

##### Share on other sites

@BrewManNH Well spotted! By all means change it.

Instead of that, if I implement Operator64 functions, Int() could be removed. It should not really be needed here neither, but because of rounding inaccuracies, I added it to be on the safe side. That's also why I decided on division by a real factor (subtracting the remainder first): I don't trust double precision to always return an accurate result.

It's a while since I wrote this and I'm trying to remember everything I was thinking at the time. I must have written it that way because of the aforementioned reasons.

Edited by czardas
##### Share on other sites

I have modified this method to be compatible with all numbers within the positive Int64 range. This example requires operator64.au3 (see link in my signature).

CODE MOVED HERE:

Edited by czardas

## Create an account

Register a new account

• ### Similar Content

• #### How to convert String to Array without any delimiters?

By LWC,

• 6 replies
• 646 views
• #### My own Binary() Function

By Pickpocketz88,

• 3 replies
• 1,128 views
• #### [SOLVED] AutoIt Binary funcs into C#

By Colduction,

• 4 replies
• 1,982 views
• #### Convert PNG and JPG to CUR in autoit

By XGamerGuide,

• 4 replies
• 1,732 views
• #### Failed color conversion to Hex

By jmor,

• 3 replies
• 1,052 views
×

• Wiki

• Back

• #### Beta

• Git
• FAQ
×
• Create New...