Python怎么进行进制转换?

2021-08-12 17:24:40 浏览数 (3560)

我们在日常使用的数据基本都是十进制的,但对于计算机而言,二进制数据更符合计算机的运算规则,不过二进制的数据用较长的位来表示一个实际并不大的数很是麻烦,所以又有了八进制和十六进制,在计算机底层中这些都是比较常用到的进制。所以这就引发了一个问题,不同的进制之间,如何进行进制转换?在python中进制转换是python内置的功能,接下来我们就来看看python实现进制转换是怎么操作的吧。

一、导言

导语:

在计算机进行数据交换时,常常会有一个进制转换的过程,我们知道计算机只认0 和 1.在内存系统中,基本基于二进制进行运算的,但是有时候数据过于庞大,为了方便存储管理,计算机会使用十六进制存储数据,但是怎么实现数据转换呢?
我们人类由十根手指头,所以自然就使用十进制啦,每当我们数数字到10之后,于是就重0 开始继续数,所以逢十进一就这么来了。

对于其它进制呢,也是同样的,比如最常见的二进制,也就是逢二进一,慢慢来,依次类推,所以数学的世界是多么的奇妙呀!

今天给大家带来的是使用 Python 实现进制转换,内容包括如下:

dec(十进制)—> bin(二进制)
dec(十进制)—> oct(八进制)
dec(十进制)—> hex(十六进制)

二、各种进制介绍

在转换之前,我们先了解以下各种进制

十进制(Decimal)

我们所熟知的十进制,其实是从 0 开始,数到 9 之后,就跳到 10,这样就变成了 10,数数大家总会把

二进制(Binary)

二进制同理,从 0 开始也就是 00(前面的一个0可以省去,但是为了更好的描述,所以保留),到 01,也变成了 10【对应十进制中的 3】,然后是 11【对应十进制中的 4】,100【十进制中的5】。。。以此类推

因为 二进制 的英文单词是 binary,所以在计算机运算的过程中,使用二进制会用如下方法,0b11(4),0b1101(13)等等

八进制(Octal)

理解了二进制,在理解八进制就很容易了,八进制是逢八进一,范围是 0~7,对比一下二进制,就很好理解啦!!

十六进制(Hexadecimal)

十六进制就可能会相对复杂一点点,十六进制是用数字 0~9 和 英文字母 A - F(大小写随意) 表示,因此 A代表 10, F代表 15。为什么在计算机领域中,十六进制用途会如此广泛呢?

给大家看一个对比:

数据长度对比

当数据比较大的时候,二进制显然不再那么使用,再看使用十六进制,就简短很多。

十六进制的运用领域可不止如此,比如原画师调色的时候,如果使用 RGB 三原色的话,那就会有 256 x 256 x 256 种组合,我们就可以使用十六进制,把每一种颜色对比转换成 十六进制字符,就会方便很多,以下是我之前调色的时候写的一个很简单一个 C 语言小程序,呃,似乎有点跑题了,哈哈,不管了

#include<stdio.h>
#include<stdlib.h> 
int main()
{
	printf("rgb三原色转16进制
");
	int a,b,c,d;
	while(d != 2){
		printf("输入1继续,输入2退出
");
		scanf("%d",&d);
		scanf("%d%d%d",&a,&b,&c);
		printf("[%x %x %x]
",a,b,c); //%x 可以直接把我们输入的十进制转换为 十六进制
	}
	return 0;
} 

三、使用 Python 代码完成转换

3.1 十进制转换为二进制

我记得不太清楚是啥时候第一次学进制转换的,进制转换常用的方法就是对 2 取余数,然后得到余数反转连在一起就是 我们所需要的二进制,举个例子,比如我要计算 十进制数 13 的 二进制是多少?


除2取余法

这也是老师教我们的方法,也是我们第一次接触进制转换的时候,用目标数 num 对 2求 余数,直到 商为 0 的时候,结束,然后将余数反向组合输出,及为我们所求的 2 进制数。有的同学会问,我怎么就能这么确定这就是 13 对应的 2 进制数呢?

答曰:

由于二进制的特殊性,数字从右边往左边数,依次对应 20 x 1 + 21 x 0 + 22x 1 + 23 x 1 = 1 +4 +8 = 13, 给大家一个速记口诀,1,2,4,8,16,32,64,128,256,512,1024。分别是 20~ 210对应的值

所以有了思路,我们就可以愉快的敲代码了

# 十进制整数转二进制

def dec_to_bin(num): #函数名做到见其名知其意

l = [] # 创建一个空列表

if num<0: # 是负数转换成整数

return "-"+ dec_to_bin(abs()) # 如过是负数,先转换成正数

while True:

num, reminder = divmod(num,2) # 短除法,对2求,分别得到除数 和 余数、这是 Python 的特有的一个内置方法,分别可以到商 及 余数

l.append(str(reminder)) # 把获得的余数 存入字符串

if num == 0: # 对应了前面的话,当商为 0时,就结束啦

return “”.join(l[::-1]) # 对列表中的字符串进行逆序拼接,得到一个二进制字符串

3.2 十进制转八进制

理解了二进制的转换,八进制一样不难。同样是目标数 num对八 求商,留余数,照这个思路走。检验的时候,一样,把 2n把2 替换成 8即可。

看代码:

和 二进制 的基本没啥却别

# 十进制转八进制
def dec_to_oct(num):
 l = []
 if num<0:
 return "-"+ dec_to_bin(abs(num)) # 如过是负数,先转换成正数
 while True:
 num, reminder = divmod(num,8) # 短除法,对2求,分别得到除数 和 余数、
 l.append(str(reminder)) # 把获得的余数 存入字符串
 if num == 0:
 return "".join(l[::-1]) # 对列表中的字符串进行逆序拼接,得到一个二进制字符串

3.3 十进制转十六进制

前面说过,十六进制相比二进制,八进制会复杂一点,但是方法是一样的

# 十进制转十六进制(这个相对麻烦一点,因为,十六进制包含 A-F,大小写不敏感)
def dec_to_hex(num):
 base = [str(x) for x in range(10)] +[chr(x) for x in range(ord('A'),ord("A")+6)] # 前者把 0 ~ 9 转换成字符串存进列表 base 里,后者把 A ~ F 存进列表
 l = []
 if num<0:
 return "-"+dec_to_hex(abs(num))
 while True:
 num,rem = divmod(num,16) # 求商 和 留余数
 l.append(base[rem])
 if num == 0:
 return "".join(l[::-1])

最后看一下运行结果,是不是很方便呢?当然 Python 有内置的方法,比如我们直接输入 十进制数,通过 bin(n) 转为二进制,oct(n) 转为 八进制,hex(n) 转为十六进制。但是原理了解以下还是很有必要的,你说是不是呢?

到此这篇python实现进制转换的文章到这里就结束了,希望能对小伙伴有一定的帮助,也希望大家以后多多支持W3Cschool