欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python常見類型轉換的小結

 更新時間:2023年02月21日 11:06:49   作者:ftzchina  
本文主要介紹了Python常見類型轉換的小結,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

近期在工作中常常接觸到各種轉換,如字符串轉byte,byte轉字符串,還有byte數組轉成報文能接納的格式(bin格式的十六進制)。故有必要系統(tǒng)的總結一下Python中常見的類型轉換。

一:常見類型的概念

類型舉例說明
二進制a = 0b1010二進制以0b打頭
八進制b = 0o2345八進制以0o打頭(注意是字母的o)
十進制c = 500十進制沒有前綴
十六進制d = 0x12ff十六進制以0x打頭
字符串e = "ftz"字符串的內容用引號或雙引號括住
字節(jié)f = b'f12345'字節(jié)以b修飾,內容用引號或雙引號括住
bin十六進制g = b'\x18\x17\x25'報文中的碼流存在形式

二:類型轉換

1,二進制,八進制,十進制,十六進制轉換

>>> var = 100
>>> bin(var) #其他進制轉二進制
'0b1100100'
>>> oct(var) #其他進制轉八進制
'0o144'
>>> int(var) #其他進制轉十進制
100
>>> hex(var) #其他進制轉十六進制
'0x64'
>>>

2,數值字符串轉換

>>> var = 100
>>>
>>> strNum = str(var) #數值轉字符串
>>> strNum
'100'
>>>
>>> intNum = int(strNum) #字符串轉數值
>>> intNum
100
>>>

注意:字符串轉數值常見,轉換成功的前提是被轉換的對象只有全是數字字符才可以,不然會報錯如下所示,此場景的轉換一般在轉換前要對對象進行判斷用字符串的方法isdigit()

>>> int('abc')
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ValueError: invalid literal for int() with base 10: 'abc'
>>> 'abc'.isdigit()
False
>>> '124'.isdigit()
True
>>>

3,字符串和字節(jié)byte轉換

解碼的本質是選擇二進制對應的圖形,編碼的本質是把字符圖形轉成相應編碼的二進制。這只是一種顯示的變化,在內存上并不一定有變化

>>> byteMyName = b'ftz'
>>> strMyName = 'ftz'
>>>
>>> strMyName.encode() #字符串轉byte
b'ftz'
>>> byteMyName.decode() #byte轉字符串
'ftz'

下面具體看下兩個轉換方法

decode方法有兩個參數,encoding默認是用'utf-8'進行解碼,errors默認用'strict'模式,如果需要一定的容錯,則用'ignore'

 |  decode(self, /, encoding='utf-8', errors='strict')
 |      Decode the bytes using the codec registered for encoding.
 |
 |      encoding
 |        The encoding with which to decode the bytes.
 |      errors
 |        The error handling scheme to use for the handling of decoding errors.
 |        The default is 'strict' meaning that decoding errors raise a
 |        UnicodeDecodeError. Other possible values are 'ignore' and 'replace'
 |        as well as any other name registered with codecs.register_error that
 |        can handle UnicodeDecodeErrors.

 decode() 方法的語法格式如下:

bytes.decode([encoding="utf-8"][,errors="strict"])

 decode() 方法用于將 bytes 類型的二進制數據轉換為 str 類型,這個過程也稱為“解碼”

decode()參數及含義

參數含義
bytes表示要進行轉換的二進制數據。
encoding="utf-8"指定解碼時采用的字符編碼,默認采用 utf-8 格式。當方法中只使用這一個參數時,可以省略“encoding=”,直接寫編碼方式即可。

注意,對 bytes 類型數據解碼,要選擇和當初編碼時一樣的格式。
errors = "strict"指定錯誤處理方式,其可選擇值可以是:
  • strict:遇到非法字符就拋出異常。
  • ignore:忽略非法字符。
  • replace:用“?”替換非法字符。
  • xmlcharrefreplace:使用 xml 的字符引用。
該參數的默認值為 strict。

encode方法同樣有兩個參數,encoding默認是用'utf-8'編碼進行轉換

 |  encode(...)
 |      S.encode(encoding='utf-8', errors='strict') -> bytes
 |
 |      Encode S using the codec registered for encoding. Default encoding
 |      is 'utf-8'. errors may be given to set a different error
 |      handling scheme. Default is 'strict' meaning that encoding errors raise
 |      a UnicodeEncodeError. Other possible values are 'ignore', 'replace' and
 |      'xmlcharrefreplace' as well as any other name registered with
 |      codecs.register_error that can handle UnicodeEncodeErrors.

 encode() 方法的語法格式如下:

str.encode([encoding="utf-8"][,errors="strict"])

注意,格式中用 [] 括起來的參數為可選參數,也就是說,在使用此方法時,可以使用 [] 中的參數,也可以不使用。 

encode()參數及含義

參數含義
str表示要進行轉換的字符串。
encoding = "utf-8"指定進行編碼時采用的字符編碼,該選項默認采用 utf-8 編碼。例如,如果想使用簡體中文,可以設置 gb2312。

當方法中只使用這一個參數時,可以省略前邊的“encoding=”,直接寫編碼格式,例如 str.encode("UTF-8")。
errors = "strict"指定錯誤處理方式,其可選擇值可以是:
  • strict:遇到非法字符就拋出異常。
  • ignore:忽略非法字符。
  • replace:用“?”替換非法字符。
  • xmlcharrefreplace:使用 xml 的字符引用。
該參數的默認值為 strict。

4,報文數據包和其他類型的互轉

上面的都是鋪墊,本節(jié)將是要重點介紹的內容。在用scapy構造報文或者編輯報文的過程中,常常需要從報文中提取我們感興趣的內容或者將我們改造的數據插入到報文中。這里面就需要用到各種轉換。最基本的操作就是將bin十六進制(報文中的數據,也稱為碼流)轉int、轉byte、轉str。相反插入一段數據或者構造的數據到報文中,則是將int、byte、str類型轉成bin十六進制。

下面將對十六進制碼流和int、byte、str互轉進行定義

bin十六進制轉int將二進制文件中的b“\x01\x79”轉為“377”的過程。本質上講,就是把一個byte型十六進制數,轉成十進制數的過程。(注意區(qū)別:int(0x178)時參數0x179是16進制整型而b’\x01\x79’是byte數組)
int轉bin十六進制將“377”轉為二進制文件中的b“\x01\x79”的過程。本質上講,就是把一個十進制數,轉成byte型十六進制數的過程。(注意區(qū)別:hex(377)得到的0x179是16進制整型而b’\x01\x79’是byte數組)
bin十六進制轉byte將二進制文件中的b“\x04\xf9\x38\xad\x13\x26”取為b‘04f9381326’的過程。本質上講,就是將每個十六進制數(4bit),轉成一個采用ascii編碼的byte(8bit)的過程
byte轉bin十六進制將b‘04f9381326’取為二進制文件中的b“\x04\xf9\x38\xad\x13\x26”的過程。本質上講,就是將每個采用ascii編碼的byte(8bit),轉成一個十六進制數(4bit)的過程
bin十六進制轉str將二進制文件中b’\x48\x54\x54\x50’取為字符串‘HTTP’的過程。本質上講,就是將ascii編碼轉成對應字符的過程。
str轉bin十六進制將字符串‘HTTP’取為二進制文件中b’\x48\x54\x54\x50’的過程。本質上講,字符轉成就是對應的ascii編碼的過程

4.1 bin十六進制與int互轉實現

        bin十六進制轉int主要在分析二進制文件、數據包頭時獲取長度等值時使用;相反,int轉bin十六進制就是在構造二進制文件、數據包頭時寫入長度等值時使用。

        另外注意把bin十六進制當數值時有大端和小端兩種模式,大端意思是開頭(低地址)權重大,小端為開頭(低地址)權重小。文件系統(tǒng)一般用小端模式,網絡傳輸一般用大端模式。

轉換方法說明
int轉bin十六進制to_bytes(lenght,byteorder)lenght表示轉成的多少個字節(jié);byteorder可為big或little分別表示轉bin十六進制時使用大端模式還是小端模式
bin十六進制轉intint.from_bytes(byte_var,byteorder)byte_var是要轉成數值的變bin十六進制變量,byteorder還是一樣可為big或little,分別表示從bin十六進制轉為數值時把bin十六進制當大端模式還是小端模式處理

舉例:

將端口的對應的碼流\xdc\x39轉成56377

>>> int.from_bytes(b'\xdc\x39','big')
56377
>>>

將56377轉成碼流\xdc\x39

>>> port = 56377
>>> byteFromInt = port.to_bytes(2,'big')
>>> byteFromInt
b'\xdc9'
>>> byteFromInt == b'\xdc\x39'
True

轉出來為什么是\xdc9,我們查一下ascii碼表,9對應的十六進制就是\x39

4.2 bin十六進制和byte互轉實現

bin十六進制轉byte主要在分析二進制文件、數據包頭時獲取mac地址、密鑰等平時就以十六進制表示的值時使用;相反,byte轉bin十六進制就是在構造二進制文件、數據包頭時寫入mac地址、密鑰等平時就以十六進制表示的值時使用。這在用scapy構造數據包或者轉換數據包時會經常用到,這里要用到第三方庫binascii,使用時需要先導入

轉換方法說明
bin十六進制轉bytebinascii.b2a_hex(bin_var)bin_var為byte變量常從二進制文件中讀出; 如binascii.b2a_hex(b’\x04\xf9\x38\xad\x13\x26’)結果為b’04f9381326‘
byte轉bin十六進制binascii.a2b_hex(hex_byte_var)hex_byte_var為十六進制字節(jié)串; 如binascii.a2b_hex(b’04f9381326’)結果為b’\x04\xf98\x13&’(8對應的ascii編碼是38,&對應的ascii編碼是26)

舉例:

>>> import binascii
>>> binascii.b2a_hex(b'\x48\x6f\x73\x74\x3a\x20\x63') #bin十六進制轉byte
b'486f73743a2063'
>>>
>>> binascii.a2b_hex(b'486f73743a2063') #byte轉bin十六進制
b'Host: c'
>>>

實際使用中我們經常會構造十六進制碼流,然后將碼流格式化成byte型,最后將byte轉成bin十六進制

4.3 bin十六進制與str互轉

bin十六進制轉主要在分析二進制文件、數據包頭時獲取其量的字符串時使用;相反,byte轉bin十六進制就是在構造二進制文件、數據包頭時寫入字符串時使用。

bin十六進制與str互轉其實就是字符串和byte互轉;此處的bin十六進制就是byte的本質。(b’\x48\x54\x54\x50’和b’HTTP’在內存中是一模一樣的)

轉換方法說明
bin十六進制轉strdecode在第3節(jié)中有詳細介紹
str轉bin十六進制encode在第3節(jié)中有詳細介紹

舉例:

>>> byteHost = b'\x48\x6f\x73\x74'
>>>
>>> byteHost.decode()
'Host'
>>>
>>> str = 'Host'
>>> str.encode()
b'Host'
>>>

到此這篇關于Python常見類型轉換的小結的文章就介紹到這了,更多相關Python常見類型轉換內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:

相關文章

  • Python使用Selenium WebDriver的入門介紹及安裝教程(最新推薦)

    Python使用Selenium WebDriver的入門介紹及安裝教程(最新推薦)

    這篇文章主要介紹了Python使用Selenium WebDriver的入門介紹及安裝教程,本文使用環(huán)境為python3.11+win10 64位+firefox瀏覽器,所以本文使用的瀏覽器驅動是Firefox的geckodriver ,如果你使用的是其他瀏覽器,那么選擇自己對應的瀏覽器驅動程序即可,需要的朋友可以參考下
    2023-04-04
  • python如何生成密碼字典

    python如何生成密碼字典

    這篇文章主要介紹了python如何生成密碼字典,密碼字典主要是配合解密使用,下面利用python實現生成密碼字典,需要的小伙伴可以參考一下
    2022-03-03
  • Python實現檢測SSL證書是否過期

    Python實現檢測SSL證書是否過期

    我們知道 SSL 證書是會過期的,一旦過期之后需要重新申請,如果沒有及時更換證書的話,就有可能導致網站出問題,所以本文介紹了如何利用Python實現檢測SSL證書是否過期,需要的可以參考下
    2023-08-08
  • numpy找出array中的最大值,最小值實例

    numpy找出array中的最大值,最小值實例

    下面小編就為大家分享一篇numpy找出array中的最大值,最小值實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-04-04
  • 關于Python字符編碼與二進制不得不說的一些事

    關于Python字符編碼與二進制不得不說的一些事

    這篇文章主要給大家介紹了關于Python字符編碼與二進制不得不說的一些事,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-10-10
  • Python算法模塊之hashlib模塊詳解

    Python算法模塊之hashlib模塊詳解

    這篇文章主要介紹了Python算法模塊之hashlib模塊詳解,hash是一種算法,不同的hash算法只是復雜度不一樣,該算法接受傳入的內容,經過運算得到一串hash值,本文提供了部分實例代碼方便理解,需要的朋友可以參考下
    2023-08-08
  • python實現微信打飛機游戲

    python實現微信打飛機游戲

    這篇文章主要為大家詳細介紹了python實現微信打飛機游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • 使用tensorflow DataSet實現高效加載變長文本輸入

    使用tensorflow DataSet實現高效加載變長文本輸入

    今天小編就為大家分享一篇使用tensorflow DataSet實現高效加載變長文本輸入,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-01-01
  • Python多圖片合并PDF的方法

    Python多圖片合并PDF的方法

    今天小編就為大家分享一篇關于Python多圖片合并PDF的方法,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • python的函數和方法(上)

    python的函數和方法(上)

    這篇文章主要為大家詳細介紹了python的函數和方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11

最新評論