python十六進制轉十進制
Ⅰ python16進制轉十進制
可以使用Python內置的`int`函數將16進制數轉換為十進制數。
解釋:
1. Python中的16進制與十進制轉換:在Python中,可以使用不同的方法將16進制數轉換為十進制數。由於Python內置了這種轉換功能,我們可以直接使用內置函數來完成這一任務。
2. 使用int函數進行轉換:對於將16進制數轉換為十進制數,可以使用`int`函數,並指定第二個參數為進制數。這是因為`int`函數可以識別不同進制的數字字元串並將其轉換為十進制數。例如,如果有一個16進制數`'A'`,可以直接使用`int`將其轉換為十進制數。這是因為Python能夠識別字元串中的字母和數字分別代表不同的值。
3. 轉換過程的具體細節:當調用`int`函數並傳遞兩個參數時,第一個參數是要轉換的數字字元串,第二個參數是字元串所代表的進制數。Python會按照指定的進制解釋字元串中的每個字元,並將結果轉換為十進制數。因此,無論輸入的字元串有多長或包含多少字元,只要它們是有效的十六進制數字,都可以使用這種方法進行轉換。這種轉換是快速且准確的,是處理數字數據時的常用操作。
Ⅱ python將十六進制轉為十進制數字的程序怎麼寫
把十六進制的字串轉為十進制數字:
Python代碼
>>> print int('ff', 16)
255
>>> print int('ff', 16)
255
把十進制數字轉換為以十六進製表示之字串,可調用內置的hex()函數:
Python代碼
>>> print hex(255)
0xff
>>> print hex(255)
0xff
調用BinAscii模塊其中的b2a_hex()函數,可把以ASCII編碼的文字以十六進製表示:
Python代碼
>>> print binascii.b2a_hex('A')
41
>>> print binascii.b2a_hex('A')
41
反之也可把以十六進製表示的文字,換成以ASCII編碼的文字:
Python代碼
>>>print binascii.a2b_hex('41')
「A」
Ⅲ (三)實踐出真知——python常用的十進制、16進制、字元串、位元組串之間的轉換
在協議解析中,數據轉換問題頻現,例如二進制與十進制、位元組串與整數之間的互轉。本文將介紹Python中十進制、十六進制、字元串、位元組串之間的轉換方法。
一、十進制與十六進制互轉
Python提供了內置函數`hex()`與`int()`來完成轉換。將十進制數轉換為十六進制,使用`hex()`;將十六進制數轉換為十進制,使用`int()`。
例如:將十進制數10轉換為十六進制,執行`hex(10)`,結果為`'0xa'`;將十六進制數`'0xa'`轉換為十進制數,執行`int('0xa', 16)`,結果為10。
二、字元串與位元組串互轉
Python中的字元串默認為Unicode編碼,位元組串則是位元組形式的數據。使用`bytes()`與`str()`函數進行轉換。
例如:將字元串`'hello'`轉換為位元組串,執行`bytes('hello', 'utf-8')`,得到位元組串`b'hello'`;將位元組串`b'hello'`轉換為字元串,執行`str(b'hello')`,得到字元串`'hello'`。
三、整數與位元組串互轉
整數轉位元組串,使用`bytes()`;位元組串轉整數,使用`int()`。在位元組串轉整數時,若位元組串為有符號,需指明基數(2)。
例如:將整數10轉換為位元組串,執行`bytes(10, 'utf-8')`,得到位元組串`b'\x0a'`;將有符號位元組串`b'\xff'`轉換為整數,執行`int(b'\xff', 2)`,得到整數-1(二進制補碼形式)。
以上是Python中常見數據類型之間的轉換方法,理解並熟練掌握這些轉換,對於協議解析與數據處理等場景將大有裨益。
Ⅳ python中的進制轉換和原碼,反碼,補碼
python中的進制轉換和原碼,反碼,補碼
計算機文件大小單位
b = bit 位(比特)
B = Byte 位元組
1Byte = 8 bit #一個位元組等於8位 可以簡寫成 1B = 8b
1KB = 1024B
1MB = 1024KB
1GB = 1024MB
1TB = 1024GB
1PB = 1024TB
1EB = 1024PB
進制分類
二進制:由2個數字組成,有0 和 1 python中標志:0b
八進制:由8個數字組成,有0,1,2,3,4,5,6,7 python中標志:0o
十進制:有10個數字組成,有0,1,2,3,4,5,6,7,8,9 python中標志:無
十六進制:有16個數字組成,有0,1,2,3,4,5,6,7,8,9,a,b,c,d,e,f(進制字母大小寫都可以,分別代表10,11,12,13,14,15) python中標志:0x
python中的進制轉換:
其他進制轉換為十進制:int(相應進制)
其他進制轉換為二進制:bin(相應進制)
其他進制轉換為八進制:oct(相應進制)
其他進制轉換為十六進制:hex(相應進制)
二進制 轉化成 十進制:
例: 0b10100101
運算:1* 2^0 + 0* 2^1 + 1* 2^2 + 0* 2^3 + 0* 2^4 + 1* 2^5 + 0* 2^6 + 1* 2^7=
1 + 0 + 4 + 0 + 0 + 32 + 0 + 128 = 165
八進制 轉化成 十進制:
例: 0o127
運算:7*8^0 + 2*8^1 + 1*8^2 = 7+16+64 = 87
十六進制 轉化成 十進制:
例: 0xff
運算:15*16^0 + 15*16^1 = 255
十進制 轉化成 二進制:
426 => 0b110101010
運算過程: 用426除以2,得出的結果再去不停地除以2,
直到除完最後的結果小於2停止,
在把每個階段求得的余數從下到上依次拼接完畢即可
十進制 轉化成 八進制:
426 => 0o652
運算過程: 用426除以8,得出的結果再去不停地除以8,
直到除完最後的結果小於8停止,
在把每個階段求得的余數從下到上依次拼接完畢即可
十進制 轉化成 十六進制:
運算過程: 用426除以16,得出的結果再去不停地除以16,
直到除完最後的結果小於16停止,
在把每個階段求得的余數從下到上依次拼接完畢即可。
相關推薦:《Python視頻教程》
原碼,反碼,補碼
實際人們看到的數字是原碼轉化之後顯示出來的。
而原碼是通過補碼得到的。
計算機的所有數據在底層都是以二進制的補碼形式存儲。
***進制轉換的時候需要先把內存存儲的補碼拿出來變成原碼在進行轉換輸出***
反碼:二進制碼0變1,1變0叫做反碼,反碼用於原碼補碼之間的轉換。
補碼:用來做數據的存儲運算,可以實現計算機底層的減法操作,因而提出(可以表達出一個數的正負)。
也就是說默認計算機只會做加法,例:5+(-3) => 5 - 3。
乘法除法是通過左移和右移 << >> 來實現。
正數高位補0,負數高位補1。
正數:
原碼 = 反碼 = 補碼
負數:
反碼 = 原碼取反(除高位)
補碼 = 反碼加1
反碼 = 補碼減1
原碼 = 反碼取反(除高位)
我們會發現,在取反前減1和在取反後加1的效果是一樣的,這就和-2-1 = -(2+1)一個道理,所以會得出這樣的規律:
原碼 = 補碼取反加1
補碼 = 原碼取反加1
一個數在計算機中的二進製表示形式, 叫做這個數的機器數。機器數是帶符號的,在計算機用一個數的最高位存放符號, 叫符號位正數為0, 負數為1。
比如
正數1在計算機中的存儲即為
0 00000000000000000000001
負數1 在計算機中的存儲即為
1 00000000000000000000001
一個正數,轉換為二進制位就是這個正數的原碼。負數的絕對值轉換成二進制位然後在高位補1就是這個負數的原碼。
正數的反碼就是原碼,負數的反碼等於原碼除符號位以外所有的位取反。
正數的補碼與原碼相同,負數的補碼為 其原碼除符號位外所有位取反(得到反碼了),然後最低位加1。
所以原碼,反碼,補碼正數情況下是一致的,負數情況下是不一致的。
計算機的運算過程實際就是補碼相加的一個過程。
比如-2 + 3
-2 的原碼為
1 000000000000000000000000010
反碼為:
1 111111111111111111111111101
補碼為:
1 111111111111111111111111110
3的原碼為
0 000000000000000000000000011
反碼為:
0 000000000000000000000000011
補碼為:
0 000000000000000000000000011
那麼二者補碼相加結果為
1 111111111111111111111111110
+
0 000000000000000000000000011
=
10 000000000000000000000000001(計算機存儲為32位,故前面溢出的1被舍棄,高位為0)
0 000000000000000000000000001
結果為1
再比如-2 + 1
-2 的原碼為
1 000000000000000000000000010
反碼為:
1 111111111111111111111111101
補碼為:
1 111111111111111111111111110
1的原碼為
0 000000000000000000000000001
1的反碼為:
0 000000000000000000000000001
1的補碼為:
0 000000000000000000000000001
二者的補碼相加結果為
1 111111111111111111111111110
+
0 000000000000000000000000001
=
1 111111111111111111111111111
得出的補碼轉化為原碼, 最低位減一得到反碼,然後除符號位外所有位取反,得到結果
1 000000000000000000000000001
結果為1