downloads | documentation | faq | getting help | mailing lists | licenses | wiki | reporting bugs | php.net sites | links | conferences | my php.net

search for in the

bindec> <atanh
[edit] Last updated: Thu, 12 Jan 2012

view this page in

base_convert

(PHP 4, PHP 5)

base_convertConvert a number between arbitrary bases

Descrierea

string base_convert ( string $number , int $frombase , int $tobase )

Returns a string containing number represented in base tobase. The base in which number is given is specified in frombase. Both frombase and tobase have to be between 2 and 36, inclusive. Digits in numbers with a base higher than 10 will be represented with the letters a-z, with a meaning 10, b meaning 11 and z meaning 35.

Avertizare

base_convert() may lose precision on large numbers due to properties related to the internal "double" or "float" type used. Please see the Floating point numbers section in the manual for more specific information and limitations.

Parametri

number

The number to convert

frombase

The base number is in

tobase

The base to convert number to

Valorile întoarse

number converted to base tobase

Exemple

Example #1 base_convert() example

<?php
$hexadecimal 
'A37334';
echo 
base_convert($hexadecimal162);
?>

Exemplul de mai sus va afișa:

101000110111001100110100

Vedeți de asemenea

  • intval() - Obține valoarea întreagă a unei variabile



bindec> <atanh
[edit] Last updated: Thu, 12 Jan 2012
 
add a note add a note User Contributed Notes base_convert
Vlado Nenov 24-Jan-2012 01:34
For bigger numbers, base_convert() returns wired numbers, use some of the functions from the comments until it is fixed.

Test your PHP version with the following code:

$code_1 = "F255I000000";
$binary_1 = base_convert($code_1, 31, 2);
echo "code 1: $code_1\n";
echo "code 2: ".base_convert($binary_1, 2, 31);

if code 1 and code 2 are the same, then everything is OK...
PHPCoder at niconet2k dot com 17-Nov-2011 03:45
Convert an arbitrarily large number from any base to any base.

string convBase(string $numberInput, string $fromBaseInput, string $toBaseInput)
$numberInput number to convert as a string
$fromBaseInput base of the number to convert as a string
$toBaseInput base the number should be converted to as a string
examples for $fromBaseInput and $toBaseInput
'0123456789ABCDEF' for Hexadecimal (Base16)
'0123456789' for Decimal (Base10)
'01234567' for Octal (Base8)
'01' for Binary (Base2)
You can really put in whatever you want and the first character is the 0.
Examples:

<?php
convBase
('123', '0123456789', '01234567');
//Convert '123' from decimal (base10) to octal (base8).
//result: 173

convBase('70B1D707EAC2EDF4C6389F440C7294B51FFF57BB', '0123456789ABCDEF', '01');
//Convert '70B1D707EAC2EDF4C6389F440C7294B51FFF57BB' from hexadecimal (base16) to binary (base2).
//result:
//111000010110001110101110000011111101010110000101110
//110111110100110001100011100010011111010001000000110
//001110010100101001011010100011111111111110101011110
//111011

convBase('1324523453243154324542341524315432113200203012', '012345', '0123456789ABCDEF');
//Convert '1324523453243154324542341524315432113200203012' from senary (base6) to hexadecimal (base16).
//result: 1F9881BAD10454A8C23A838EF00F50

convBase('355927353784509896715106760','0123456789','Christopher');
//Convert '355927353784509896715106760' from decimal (base10) to undecimal (base11) using "Christopher" as the numbers.
//result: iihtspiphoeCrCeshhorsrrtrh

convBase('1C238Ab97132aAC84B72','0123456789aAbBcCdD', '~!@#$%^&*()');
//Convert'1C238Ab97132aAC84B72' from octodecimal (base18) using '0123456789aAbBcCdD' as the numbers to undecimal (base11) using '~!@#$%^&*()' as the numbers.
//result: !%~!!*&!~^!!&(&!~^@#@@@&

function convBase($numberInput, $fromBaseInput, $toBaseInput)
{
    if (
$fromBaseInput==$toBaseInput) return $numberInput;
   
$fromBase = str_split($fromBaseInput,1);
   
$toBase = str_split($toBaseInput,1);
   
$number = str_split($numberInput,1);
   
$fromLen=strlen($fromBaseInput);
   
$toLen=strlen($toBaseInput);
   
$numberLen=strlen($numberInput);
   
$retval='';
    if (
$toBaseInput == '0123456789')
    {
       
$retval=0;
        for (
$i = 1;$i <= $numberLen; $i++)
           
$retval = bcadd($retval, bcmul(array_search($number[$i-1], $fromBase),bcpow($fromLen,$numberLen-$i)));
        return
$retval;
    }
    if (
$fromBaseInput != '0123456789')
       
$base10=convBase($numberInput, $fromBaseInput, '0123456789');
    else
       
$base10 = $numberInput;
    if (
$base10<strlen($toBaseInput))
        return
$toBase[$base10];
    while(
$base10 != '0')
    {
       
$retval = $toBase[bcmod($base10,$toLen)].$retval;
       
$base10 = bcdiv($base10,$toLen,0);
    }
    return
$retval;
}
?>
bpds 29-Sep-2011 11:47
A simple function to convert an int to any base.

<?php
function intToAlphaBaseN($n,$baseArray) {
   
$l=count($baseArray);
   
$s = '';
    for (
$i = 1; $n >= 0 && $i < 10; $i++) {
       
$s $baseArray[($n % pow($l, $i) / pow($l, $i - 1))].$s;
       
$n -= pow($l, $i);
    }
    return
$s;
}

$alpha=array('a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z');
$r=rand(0, 99999999999);
echo(
intToAlphaBaseN($r,$alpha));
?>
JR 15-Aug-2011 10:19
Short arabic2roman conveter:

<?php
function rome($N){
       
$c='IVXLCDM';
        for(
$a=5,$b=$s='';$N;$b++,$a^=7)
                for(
$o=$N%$a,$N=$N/$a^0;$o--;$s=$c[$o>2?$b+$N-($N&=-2)+$o=1:$b].$s);
        return
$s;
}
?>

And it works :)
bryan at bryanruiz dot com 02-Feb-2011 08:11
A RFC 4648 Compliant Base32 encode.  Send me an email if you end up making this thing more efficient with bitwise operations and whatever else.

<?php

/**
 * Encode in Base32 based on RFC 4648.
 * Requires 20% more space than base64 
 * Great for case-insensitive filesystems like Windows and URL's  (except for = char which can be excluded using the pad option for urls)
 *
 * @package default
 * @author Bryan Ruiz
 **/
class Base32 {

   private static
$map = array(
       
'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', //  7
       
'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', // 15
       
'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', // 23
       
'Y', 'Z', '2', '3', '4', '5', '6', '7', // 31
       
'='  // padding char
   
);
   
   private static
$flippedMap = array(
       
'A'=>'0', 'B'=>'1', 'C'=>'2', 'D'=>'3', 'E'=>'4', 'F'=>'5', 'G'=>'6', 'H'=>'7',
       
'I'=>'8', 'J'=>'9', 'K'=>'10', 'L'=>'11', 'M'=>'12', 'N'=>'13', 'O'=>'14', 'P'=>'15',
       
'Q'=>'16', 'R'=>'17', 'S'=>'18', 'T'=>'19', 'U'=>'20', 'V'=>'21', 'W'=>'22', 'X'=>'23',
       
'Y'=>'24', 'Z'=>'25', '2'=>'26', '3'=>'27', '4'=>'28', '5'=>'29', '6'=>'30', '7'=>'31'
   
);
   
   
/**
     *    Use padding false when encoding for urls
     *
     * @return base32 encoded string
     * @author Bryan Ruiz
     **/
   
public static function encode($input, $padding = true) {
        if(empty(
$input)) return "";
       
$input = str_split($input);
       
$binaryString = "";
        for(
$i = 0; $i < count($input); $i++) {
           
$binaryString .= str_pad(base_convert(ord($input[$i]), 10, 2), 8, '0', STR_PAD_LEFT);
        }
       
$fiveBitBinaryArray = str_split($binaryString, 5);
       
$base32 = "";
       
$i=0;
        while(
$i < count($fiveBitBinaryArray)) {   
           
$base32 .= self::$map[base_convert(str_pad($fiveBitBinaryArray[$i], 5,'0'), 2, 10)];
           
$i++;
        }
        if(
$padding && ($x = strlen($binaryString) % 40) != 0) {
            if(
$x == 8) $base32 .= str_repeat(self::$map[32], 6);
            else if(
$x == 16) $base32 .= str_repeat(self::$map[32], 4);
            else if(
$x == 24) $base32 .= str_repeat(self::$map[32], 3);
            else if(
$x == 32) $base32 .= self::$map[32];
        }
        return
$base32;
    }
   
    public static function
decode($input) {
        if(empty(
$input)) return;
       
$paddingCharCount = substr_count($input, self::$map[32]);
       
$allowedValues = array(6,4,3,1,0);
        if(!
in_array($paddingCharCount, $allowedValues)) return false;
        for(
$i=0; $i<4; $i++){
            if(
$paddingCharCount == $allowedValues[$i] &&
               
substr($input, -($allowedValues[$i])) != str_repeat(self::$map[32], $allowedValues[$i])) return false;
        }
       
$input = str_replace('=','', $input);
       
$input = str_split($input);
       
$binaryString = "";
        for(
$i=0; $i < count($input); $i = $i+8) {
           
$x = "";
            if(!
in_array($input[$i], self::$map)) return false;
            for(
$j=0; $j < 8; $j++) {
               
$x .= str_pad(base_convert(@self::$flippedMap[@$input[$i + $j]], 10, 2), 5, '0', STR_PAD_LEFT);
            }
           
$eightBits = str_split($x, 8);
            for(
$z = 0; $z < count($eightBits); $z++) {
               
$binaryString .= ( ($y = chr(base_convert($eightBits[$z], 2, 10))) || ord($y) == 48 ) ? $y:"";
            }
        }
        return
$binaryString;
    }
}
francesco[at]paladinux.net 22-Sep-2010 09:30
base convert is limited on standard base invented.
In some case, if you want to invented some translate code (for authorizion code 4 example) , I hope is usefull this example of base_convert-AS from decimal in 65imal base for a speedCode.
Some more specifical: you can transform using a db
$speedCodeDEC            = $idAziendaMittente.$idAziendaDestinatario.$idDDT ;

//$speedCodeDEC = 3000;

//
$BASECODE = array();
$BASECODE['items'] = 65;
$BASECODE[1]='1';
$BASECODE[2]='2';
$BASECODE[3]='3';
$BASECODE[4]='4';
....
$BASECODE[10]='a';
$BASECODE[11]='b';
$BASECODE[12]='c';
...
$BASECODE[36]='A';
$BASECODE[37]='B';
$BASECODE[38]='C';
...
$BASECODE[61]='Z';
$BASECODE[62]='/';
$BASECODE[63]='-';
$BASECODE[64]='+';
//

//print_r ($BASECODE);TEST

function creaSpeedCode ( $speedCodeDEC,$partialCode="",$BASECODE){

    @$division      = $speedCodeDEC/$BASECODE['items'];
    @$resultINT   = floor($speedCodeDEC/$BASECODE['items']);
    @$remnant          = $speedCodeDEC%$BASECODE['items'];
    $partialCode  = $BASECODE[$remnant].$partialCode;
echo "
    <br>
    Inserito speedCodeDEC:$speedCodeDEC - partialCode:$partialCode<br>
    items            : ".$BASECODE['items']."<br>
    division          : $division    <br>
    resultINT        : $resultINT    <br>
    remnant            : $remnant        <br>
    partialCode        : $partialCode    <br>
";//TEST   
    if ($resultINT > 65)     $partialCode = creaSpeedCode($resultINT,$partialCode,$BASECODE);
    return $BASECODE[$resultINT].$partialCode;
}
echo $speedCodeDEC."<br>";
echo $risultato = creaSpeedCode ( $speedCodeDEC,"",$BASECODE);
Theriault 29-Nov-2009 07:11
If you would like to convert numbers into just the uppercase alphabet base and vice-versa (e.g. the column names in a Microsoft Windows Excel sheet..A-Z, AA-ZZ, AAA-ZZZ, ...), the following functions will do this.

<?php

/**
 * Converts an integer into the alphabet base (A-Z).
 *
 * @param int $n This is the number to convert.
 * @return string The converted number.
 * @author Theriault
 *
 */
function num2alpha($n) {
   
$r = '';
    for (
$i = 1; $n >= 0 && $i < 10; $i++) {
       
$r = chr(0x41 + ($n % pow(26, $i) / pow(26, $i - 1))) . $r;
       
$n -= pow(26, $i);
    }
    return
$r;
}
/**
 * Converts an alphabetic string into an integer.
 *
 * @param int $n This is the number to convert.
 * @return string The converted number.
 * @author Theriault
 *
 */
function alpha2num($a) {
   
$r = 0;
   
$l = strlen($a);
    for (
$i = 0; $i < $l; $i++) {
       
$r += pow(26, $i) * (ord($a[$l - $i - 1]) - 0x40);
    }
    return
$r - 1;
}

?>

Microsoft Windows Excel stops at IV (255), but this function can handle much larger. However, English words will start to form after a while and some may be offensive, so be careful.
MFTM 16-Aug-2009 05:30
It might be a better function to deal with numbers over 9000. (even 10 millions)

<?php

function romanic_number($integer, $upcase = true)
{
   
$table = array('M'=>1000, 'CM'=>900, 'D'=>500, 'CD'=>400, 'C'=>100, 'XC'=>90, 'L'=>50, 'XL'=>40, 'X'=>10, 'IX'=>9, 'V'=>5, 'IV'=>4, 'I'=>1);
   
$return = '';
    while(
$integer > 0)
    {
        foreach(
$table as $rom=>$arb)
        {
            if(
$integer >= $arb)
            {
               
$integer -= $arb;
               
$return .= $rom;
                break;
            }
        }
    }

    return
$return;
}
?>
cyrilbele at yahoo dot fr 15-Apr-2009 07:58
If you want to do sharding, at some point you will need to decide which shard to target. Here is a simple function to assign the data to a particular shard based on a key (usually identifier of the row)

Here is a simple function to get the shard based on the key and the number of shards available

<?php
function getShard($key,$nbShards) {
   
$num = substr(base_convert(sha1($key), 16, 10),4,6);
    return
$num%$nbShards;
}
?>
dorantor 13-May-2008 04:42
Spent almost a day to find a bug(?) in base_convert() function when converting big values to binary:

<?php
$value
= 2919739656537;
echo
base_convert($value, 10, 2);
?>
should print
101010011111001110000010111000100101011001
in reality, prints
10101000111000001100011100110101110110100100
but that is wrong!

so, in result, I've written this two functions:
<?php
/**
 * Convert binary to decimal
 * works with big numbers
 *
 * @param string $binary
 * @return float
 */
function big_bin2dec($binary)
{
   
$result = (float)0;

   
$shift = 0;
    while (
0 < strlen($binary) ) {
       
$bit    = substr($binary, -1);
       
$binary    = substr($binary, 0, -1);
       
$result = $result + $bit*pow(2, $shift);
        ++
$shift;
    }
    return
$result;
}

/**
 * convert decimal 2 binary presentation
 *
 * @param mixed $dec
 * @return string
 */
function big_dec2bin($dec)
{
   
$result    = '';
   
$shift    = 0;
    while (
pow(2, $shift) < $dec ) {
        ++
$shift;
    }
    while (
0 <= $shift ) {
       
$pow = pow(2, $shift);
        if (
$pow <= $dec ) {
           
$dec-= $pow;
           
$result = $result . '1';
        } else {
           
$result = $result . '0';
        }
        --
$shift;
    }
    return
$result;
}
?>
Functions tested only with positive integers(that's enough for me), so if you need more than this you'll, possibly, have to rework 'em.

Simple test:
<?php
$value
= pow(2, 48);//only one bit should be set

printf("%f \n", $value);
echo
base_convert($value, 10, 2), "\n";
echo
big_dec2bin($value), "\n";
?>
prints out something similar to:
281474976710656.000000
110011001100110011001100110011001100111001010
1000000000000000000000000000000000000000000000000

I hope this will help someone :)
BTW! My phpinfo() says PHP Version 5.2.1
Ray Paseur sometimes uses GMail 06-Dec-2006 08:55
[EDIT BY danbrown AT php DOT net: This function provides conversion of Arabic numerals (those used by most of the world, the standard 1,2,3,4,...) into Roman numerals (I,II,III,IV,...).  The original author failed to provide a description, but due to the usefulness of the function, it is being preserved from deletion, and a simple description added.]

<?php
function roman_numerals($input_arabic_numeral='') {

    if (
$input_arabic_numeral == '') { $input_arabic_numeral = date("Y"); } // DEFAULT OUTPUT: THIS YEAR
   
$arabic_numeral            = intval($input_arabic_numeral);
   
$arabic_numeral_text    = "$arabic_numeral";
   
$arabic_numeral_length    = strlen($arabic_numeral_text);

    if (!
ereg('[0-9]', $arabic_numeral_text)) {
return
false; }

    if (
$arabic_numeral > 4999) {
return
false; }

    if (
$arabic_numeral < 1) {
return
false; }

    if (
$arabic_numeral_length > 4) {
return
false; }

   
$roman_numeral_units    = $roman_numeral_tens        = $roman_numeral_hundreds        = $roman_numeral_thousands        = array();
   
$roman_numeral_units[0]    = $roman_numeral_tens[0]    = $roman_numeral_hundreds[0]    = $roman_numeral_thousands[0]    = ''; // NO ZEROS IN ROMAN NUMERALS

   
$roman_numeral_units[1]='I';
   
$roman_numeral_units[2]='II';
   
$roman_numeral_units[3]='III';
   
$roman_numeral_units[4]='IV';
   
$roman_numeral_units[5]='V';
   
$roman_numeral_units[6]='VI';
   
$roman_numeral_units[7]='VII';
   
$roman_numeral_units[8]='VIII';
   
$roman_numeral_units[9]='IX';

   
$roman_numeral_tens[1]='X';
   
$roman_numeral_tens[2]='XX';
   
$roman_numeral_tens[3]='XXX';
   
$roman_numeral_tens[4]='XL';
   
$roman_numeral_tens[5]='L';
   
$roman_numeral_tens[6]='LX';
   
$roman_numeral_tens[7]='LXX';
   
$roman_numeral_tens[8]='LXXX';
   
$roman_numeral_tens[9]='XC';

   
$roman_numeral_hundreds[1]='C';
   
$roman_numeral_hundreds[2]='CC';
   
$roman_numeral_hundreds[3]='CCC';
   
$roman_numeral_hundreds[4]='CD';
   
$roman_numeral_hundreds[5]='D';
   
$roman_numeral_hundreds[6]='DC';
   
$roman_numeral_hundreds[7]='DCC';
   
$roman_numeral_hundreds[8]='DCCC';
   
$roman_numeral_hundreds[9]='CM';

   
$roman_numeral_thousands[1]='M';
   
$roman_numeral_thousands[2]='MM';
   
$roman_numeral_thousands[3]='MMM';
   
$roman_numeral_thousands[4]='MMMM';

    if (
$arabic_numeral_length == 3) { $arabic_numeral_text = "0" . $arabic_numeral_text; }
    if (
$arabic_numeral_length == 2) { $arabic_numeral_text = "00" . $arabic_numeral_text; }
    if (
$arabic_numeral_length == 1) { $arabic_numeral_text = "000" . $arabic_numeral_text; }

   
$anu = substr($arabic_numeral_text, 3, 1);
   
$anx = substr($arabic_numeral_text, 2, 1);
   
$anc = substr($arabic_numeral_text, 1, 1);
   
$anm = substr($arabic_numeral_text, 0, 1);

   
$roman_numeral_text = $roman_numeral_thousands[$anm] . $roman_numeral_hundreds[$anc] . $roman_numeral_tens[$anx] . $roman_numeral_units[$anu];
return (
$roman_numeral_text);
}
?>
CJ Dennis 05-Apr-2006 07:03
Really huge numbers might be truncated at both ends.
eg:
<?php
$binary
="11010101001111010001110101000100011110010110110".
"001111000010001010001111001100011010110110010010011010".
"001011010000001001011111110001010101101101011010101010".
"000100011101110010110010100111110001010010111010110011".
"001111111100011001011011001110001111110000101011010010";
print(
strtoupper(base_convert($binary, 2, 16)));
?>
will output:
9E8EA23CB63C0000000000000000000000000000000000000000000000000000 (64 hex digits)
when the correct result would be:
6A9E8EA23CB63C228F31AD9268B4097F156D6AA11DCB29F14BACCFF196CE3F0AD2 (66 hex digits)
Notice that as well as the result showing '0's after B63C which you would expect it is also missing the first 6A before 9E.
lindsay at bitleap dot com 18-Mar-2005 06:17
If you need to use base_convert with numbers larger then 32 bit, the following gmp implementation of base_convert should work.

<?php

/*use gmp library to convert base. gmp will convert numbers > 32bit*/
function gmp_convert($num, $base_a, $base_b)
{
        return
gmp_strval ( gmp_init($num, $base_a), $base_b );
}

?>
simon at simonster dot com 15-Jun-2004 12:05
Here are some functions for converting integers to and from base 256. Converting to base 64 is simple given these.

<?php
function to_base256($number, $from_base = 10) {
   
$binary_number = base_convert($number, $from_base, 2);
   
$final_string = "";
   
$new_length = (ceil(strlen($binary_number)/8)*8);
   
$binary_number = str_pad($binary_number, $new_length, "0", STR_PAD_LEFT);
    for(
$i=($new_length-8); $i>=0; $i-=8) {
       
$final_string = chr(base_convert(substr($binary_number, $i, 8), 2, 10)).$final_string;
    }
    return
$final_string;
}

function
from_base256($string, $to_base = 10) {
   
$number = "";
    for(
$i=0; $i<strlen($string); $i++) {
       
$number .= str_pad(base_convert(ord($string{$i}), 10, 2), 8, "0", STR_PAD_LEFT);
    }
    return
base_convert($number, 2, $to_base);
}
?>

Yes, I know that this would be more efficient if it used mod instead of base_convert, but it needs to work with integers > 32 bits.
AdamJacobMuller at AdamJacobMuller dot com 28-Apr-2004 08:20
<?php
function binarycodedstring2dec($binary) {
       
$len=strlen($binary);
       
$rows=($len/4)-1;
        if ((
$len%4)>0) {
               
$pad=$len+(4-($len%4));
               
$binary=str_pad($binary,$pad,"0",STR_PAD_LEFT);
               
$len=strlen($binary);
               
$rows=($len/4)-1;
        }
       
$x=0;
        for (
$x=0;$x<=$rows;$x++) {
               
$s=($x*4);
               
$bins=$binary[$s].$binary[$s+1].$binary[$s+2].$binary[$s+3];
               
$num=base_convert($bins,2,10);
                if (
$num>9) {
                        die(
"the string is not a proper binary coded decimal\n");
                } else {
                       
$res.=$num;
                }
        }
        return
$res;
}
?>

a binary coded decimal is converted by taking groups of four from a decimal string,
for example the binary coded decimal string
1000 = 8
10001000 does not = 136 but 88
so
binarycodedstring2dec(1000) = 8
binarycodedstring2dec(11100000111001)=3839
binarycodedstring2dec(100000111001)=839

i truly have no idea if this function will be useful to anyone, i simply failed a physics midterm because i didn't know this so i wrote this function to make sure i would never forget how to convert binary coded decimals
fiftytoo at buckeyeexpress dot com 23-Dec-2003 05:57
I needed a function to invert a hex value, which i used for setting font colors when they were on a colored background, that way i will get a contrasting color.

Im sure there are other reasons to use this, you decide!!

<?php
function InvertColor($hex) {
  return
sprintf("%06s",base_convert(($hex ^ 0xFFFFFF),10,16));
  };

print
'<td bgcolor="BB2222"><font color="'.InvertColor(0xBB2222).'">Blah</font></td>';
// Prints 44dddd as the font color, which is it's opposite on the color wheel

?>
Fips 29-Jul-2003 05:08
I wrote a function for converting numbers not only into 0-9 and a-z:

-----
<?php
function custombase_convert($numstring, $baseFrom = "0123456789", $baseTo = "0123456789")
{
   
$numstring = (string) $numstring;
   
$baseFromLen = strlen($baseFrom);
   
$baseToLen = strlen($baseTo);
    if (
$baseFrom == "0123456789") // No analyzing needed, because $numstring is already decimal
   
{
       
$decVal = (int) $numstring;
    } else {
       
$decVal = 0;
        for (
$len = (strlen($numstring) - 1); $len >= 0; $len--)
        {
           
$char = substr($numstring, 0, 1);
           
$pos = strpos($baseFrom, $char);
            if (
$pos !== FALSE)
            {
               
$decVal += $pos * ($len > 0 ? pow($baseFromLen, $len) : 1);
            }
           
$numstring = substr($numstring, 1);
        }
    }
    if (
$baseTo == "0123456789") // No converting needed, because $numstring needs to be converted to decimal
   
{
       
$numstring = (string) $decVal;
    } else {
       
$numstring = FALSE;
       
$nslen = 0;
       
$pos = 1;
        while (
$decVal > 0)
        {
           
$valPerChar = pow($baseToLen, $pos);
           
$curChar = floor($decVal / $valPerChar);
            if (
$curChar >= $baseToLen)
            {
               
$pos++;
            } else {
               
$decVal -= ($curChar * $valPerChar);
                if (
$numstring === FALSE)
                {
                   
$numstring = str_repeat($baseTo{1}, $pos);
                   
$nslen = $pos;
                }
               
$numstring = substr($numstring, 0, ($nslen - $pos)) . $baseTo{$curChar} . substr($numstring, (($nslen - $pos) + 1));
               
$pos--;
            }
        }
        if (
$numstring === FALSE) $numstring = $baseTo{1};
    }
    return
$numstring;
}
?>
------

The function arguments:
$numstring - String with number to convert. (e.g. "15" or "5F")
$baseFrom - Chars of the base the number is in. (e.g. "0123456789" for decimal or "01" for binary)
$baseTo - Chars of the base to convert the number. (e.g. "0123456789" for decimal or "01" for binary)

I wrote it for writing numbers in files, and so I convert between "0123456789" (decimal) and "\x01\x02\x03...\xFF" - uses very low disc space :-) (You could of course also add the null char (\x00), but >I< need it to seperate the numbers)
sam_at_compasspointmedia.com 06-Dec-2002 07:15
If you haven't already figured it out from the text, the higest base you can encode in is 36 (because z is 35),  try this

<?php
$compactIt
= base_convert('999',10,37);  //or anything higher
?>

and you'll get a warning.
gateschris at yahoo dot com 26-Mar-2001 09:57
if your worried about little/big edian affecting your dec to binary conversions, or just want to convert large numbers then try this bit of code:
<?php
// this little bit of code is simply to convert a 64bit number.
function convert_num ($value) {
 
$value = (string) $value;
 while (!
preg_match('/^0*$/', $value) && $j < 65) {
 
$cumulate = '';
 
$rem = '';
  for (
$i = 0; $i < strlen($value); $i++) {
   if (
$cumulate == '') {
    if (
floor(($value[$i] + $rem) / 2)) {
    
$cumulate .= floor(($value[$i] + $rem) / 2);
    }
   } else {
   
$cumulate .= floor(($value[$i] + $rem) / 2);
   }
  
$rem = $value [$i] % 2 * 10;
  }
 
$r = floor($rem / 10);
 
$re .= $r;
 
$value = $cumulate;
 
$j++;
 }  
 return
$re;
}

print
convert_num (65535);
?>
tim_converse at yahoo dot com 19-Jan-2000 08:24
base_convert expects its string arguments to be integral, and gives nonsensical answers when given floating-point strings.  For example, base_convert("1.0", 10, 2) yields "1100100".  It seems that "1.0" is being interpreted as "100".  (PHP4.0b3).
scott at mha dot ca 08-Sep-1999 09:48
This would seem to be limited to 31 bits, ie. the range of values that can be converted is 0 - 2147483647 in decimal.

Also, this will convert negative values to positive values, unlike DecHex() which will return a null string for negative values.

From what I have observed (using PHP 3.0.11) the following statements will set both a and c to a null string and set b to positive 1.

<?php
$a
= base_convert (2147483648, 10, 16);
$b = base_convert (-1, 10, 16);
$c = dechex (-1);
?>

 
show source | credits | stats | sitemap | contact | advertising | mirror sites