本文目錄一覽:
- 1、python3轉成bytes其中bytes()與encode()有什麼區別?
- 2、了解python中bytes,str和unicode的區別
- 3、python的bytes類型有什麼用,什麼情況下使用
- 4、Python文件處理里encoding和encode有事區別,bytes類型是什麼意思?
- 5、python 位元組流中的解析 b’B\x97\xc7\xae’?
python3轉成bytes其中bytes()與encode()有什麼區別?
就將str類型轉換為Bytes類型這一過程的實質而言,沒有區別.
硬要講區別,大概就是語法上的區別了,一個是函數,一個是方法.
需要傳遞函數的時候,你不能使用方法.
需要調用方法的時候,你不能寫成函數的形式.
了解python中bytes,str和unicode的區別
首先來說把Unicode轉換為為原始8位值(二進位數據),有很多種辦
編寫Python程序的時候,核心部分應該用Unicode來寫,也就是python3中的str,python2中的unicode
python3中2種表示字元序列的類型:bytes和str
前者的實例包含了原始8位值,後者的實例包含了Unicode字元
python3中接受bytes和str,並總是返回str:
def to_str(bytes_or_str):
if isinstance(bytes_or_str, bytes):
return bytes_or_str.decode(‘utf-8’)
return bytes_or_str1234
python3中接受bytes和str,並總是返回bytes:
def to_bytes(bytes_or_str):
if isinstance(bytes_or_str, str):
return bytes_or_str.encode(‘utf-8’)
return bytes_or_str1234
python2中2種表示字元序列的類型:unicode和str
與python3剛好相反:後者的實例包含了原始8位值,前者的實例包含了Unicode字元
python2中接受unicode和str,並總是返回unicode:
def to_str(bytes_or_str):
if isinstance(bytes_or_str, str):
return bytes_or_str.decode(‘utf-8’)
return bytes_or_str1234
python2中接受unicode和str,並總是返回str:
def to_bytes(bytes_or_str):
if isinstance(bytes_or_str, unicode):
return bytes_or_str.encode(‘utf-8’)
return bytes_or_str1234
python2和python3需要注意的事情
1.python2中如果str只包含7位的ASCII字元,那麼unicode和str 就是同一種類型,可以+操作
2.python3內置的open函數獲取文件句柄,默認採用utf-8的格式操作文件,python2則默認是二進位
python2 的寫法:
with open(”/temp/file.bin”,’w’)as f :
f.write(os.urandom(10))12
python3 的寫法:
with open(”/temp/file.bin”,’wb’)as f :
f.write(os.urandom(10))12
ps:如何讓你的代碼pythonic
python的bytes類型有什麼用,什麼情況下使用
當使用文本模式打開文件時,它返回一個TextIOBase的子類。
當使用二進位打開時,返回的是BufferedIOBase的子類。
準確細分為:可讀二進位模式,返回BufferReader對象;在可寫和追加模式中,返回BufferWriter對象,在讀寫模式中,返回BufferRandom。
當buffering關閉時,原始數據流,一個RawIOBase的子類將被返回。
Python文件處理里encoding和encode有事區別,bytes類型是什麼意思?
python問題我來回答你。
首先你要知道的是,字元串在Python內部的表示是unicode(統一碼、萬國碼)編碼,很多編程語言都是這麼設計的,各個國家通用編碼,因此,在做編碼轉換時,通常需要以unicode作為中間編碼,即先將其他編碼的字元串解碼(decode)成unicode,再從unicode編碼(encode)成另一種編碼。
decode的作用是將其他編碼的字元串轉換成unicode編碼,如str1.decode(‘gb2312’),表示將gb2312編碼的字元串str1轉換成unicode編碼。
encode的作用是將unicode編碼轉換成其他編碼的字元串,如str2.encode(‘gb2312’),表示將unicode編碼的字元串str2轉換成gb2312編碼。
因此,轉碼的時候一定要先搞明白,字元串str是什麼編碼,然後decode成unicode,然後再encode成其他編碼。
bytes類型是 Python 3.x版本新增的數據類型,在 Python 2.x 中是不存在的。字元串是以字元為單位進行處理的,bytes類型是以位元組為單位處理的。
bytes 只負責以位元組序列的形式(二進位形式)來存儲數據,至於這些數據到底表示什麼內容(字元串、數字、圖片、音頻等),完全由程序的解析方式決定。
說白了,bytes 只是簡單地記錄內存中的原始數據,至於如何使用這些數據,bytes 並不在意,你想怎麼使用就怎麼使用,bytes 並不約束你的行為。
bytes 類型的數據非常適合在互聯網上傳輸,可以用於網路通信編程;bytes 也可以用來存儲圖片、音頻、視頻等二進位格式的文件。
舉個例子:
b = b” # 創建一個空的bytes
b = byte() # 創建一個空的bytes
b = b’hello’ # 直接指定這個hello是bytes類型
b = bytes(‘string’,encoding=’編碼類型’) #利用內置bytes方法,將字元串轉換為指定編碼的bytes
b = str.encode(‘編碼類型’) # 利用字元串的encode方法編碼成bytes,默認為utf-8類型
bytes.decode(‘編碼類型’):將bytes對象解碼成字元串,默認使用utf-8進行解碼。
python 位元組流中的解析 b’B\x97\xc7\xae’?
這是bytes 類型,是位元組類型,不是float類型,簡而言之可以理解為字元串
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/235918.html