int
支援轉換為 int 型別的,僅有 float
、str
、bytes
,其他型別均不支援。
float -> int
會去掉小數點及後面的數值,僅保留整數部分。
int(-12.94) # -12
str -> int
如果字串中有數字(0-9)和正負號(+/-)以外的字元,就會報錯。
int(`1209`) # 1209
int(`-12`) # -12
int(`+1008`) # 1008
bytes -> int
如果 bytes 中有數字(0-9)和正負號(+/-)以外的字元,就會報錯。
int(b`1209`) # 1209
int(b`-12`) # -12
int(b`+1008`) # 1008
float
支援轉換為 float 型別的,僅有 int
、str
、bytes
,其他型別均不支援。
int -> float
int 轉換為 float 時,會自動給新增一位小數。
float(-1209) # -1209.0
str -> float
如果字串含有正負號(+/-)、數字(0-9)和小數點(.)以外的字元,則不支援轉換。
float(`-1209`) # -1209.0
float(`-0120.29023`) # -120.29023
bytes -> float
如果 bytes 中含有正負號(+/-)、數字(0-9)和小數點(.)以外的字元,則不支援轉換。
float(b`-1209`) # -1209.0
float(b`-0120.29023`) # -120.29023
complex
僅支援 int
、float
、str
轉換成 complex 型別。
int -> complex
int 轉換 complex 時,會自動新增虛數部分並以0j
表示。
complex(12) # (12+0j)
float -> complex
float 轉換 complex 時,會自動新增虛數部分並以0j
表示。
complex(-12.09) # (-12.09+0j)
str -> complex
str 轉換 complex 時,如果能轉換成 int 或 float,則會轉換後再轉為 complex。如果字串完全符合 complex 表示式規則,也可以轉換為 complex 型別值。
complex(`-12.09`) # (-12.09+0j)
complex(`-12.0`) # (-12+0j),去除了小數部分
complex(`-12`) # (-12+0j)
complex(`-12+9j`) # (-12+9j)
complex(`(-12+9j)`) # (-12+9j)
complex(`-12.0-2.0j`) # (-12-2j),去除了小數部分
complex(`-12.0-2.09j`) # (-12-2.09j)
complex(b`12`) # 報錯,不支援 bytes 轉換為 complex
complex(`12 + 9j`) # 報錯,加號兩側不可有空格
str
str()
函式可以將任意物件轉換為字串。
int -> str
int 轉換 str 會直接完全轉換。
str(12) # 12
float -> str
float 轉換 str 會去除末位為 0 的小數部分。
str(-12.90) # -12.9
complex -> str
complex 轉換 str,會先將值轉化為標準的 complex 表示式,然後再轉換為字串。
str(complex(12 + 9j)) # (12+9j)
str(complex(12, 9)) # (12+9j)
bytes -> str
bytes 和 str 的轉換比較特殊點,在 Python 3.x 中,字串和位元組不再混淆,而是完全不同的資料型別。
轉換為可執行的表示式字串:
str(b`hello world`) # b`hello world`
str()
函式指定 encoding 引數,或者使用 bytes.decode() 方法,可以作實際資料的轉換:
b`hello world`.decode() # hello world
str(b`hello world`, encoding=`utf-8`) # hello world
str(b`xe4xb8xadxe5x9bxbd`, encoding=`utf-8`) # 中國
list -> str
會先將值格式化為標準的 list 表示式,然後再轉換為字串。
str([]) # []
str([1, 2, 3]) # [1, 2, 3]
``.join([`a`, `b`, `c`]) # abc
tuple -> str
會先將值格式化為標準的 tuple 表示式,然後再轉換為字串。
str(()) # ()
str((1, 2, 3)) # (1, 2, 3)
``.join((`a`, `b`, `c`)) # abc
dict -> str
會先將值格式化為標準的 dict 表示式,然後再轉換為字串。
str({`name`: `hello`, `age`: 18}) # {`name`: `hello`, `age`: 18}
str({}) # {}
``.join({`name`: `hello`, `age`: 18}) # nameage
set -> str
會先將值格式化為標準的 set 表示式,然後再轉換為字串。
str(set({})) # set()
str({1, 2, 3}) # {1, 2, 3}
``.join({`a`, `b`, `c`}) # abc
其他型別
轉換內建物件:
str(int) # <class `int`>,轉換內建類
str(hex) # <built-in function hex>,轉換內建函式
轉換類例項:
class Hello:
pass
obj = Hello()
print(str(obj))
# <__main__.Hello object at 0x1071c6630>
轉換函式:
def hello():
pass
print(str(hello))
# <function hello at 0x104d5a048>
bytes
僅支援 str
轉換為 bytes 型別。
`中國`.encode() # b`xe4xb8xadxe5x9bxbd`
bytes(`中國`, encoding=`utf-8`) # b`xe4xb8xadxe5x9bxbd`
list
支援轉換為 list 的型別,只能是序列,比如:str、tuple、dict、set等。
str -> list
list(`123abc`) # [`1`, `2`, `3`, `a`, `b`, `c`]
bytes -> list
bytes 轉換列表,會取每個位元組的 ASCII 十進位制值並組合成列表
list(b`hello`) # [104, 101, 108, 108, 111]
tuple -> list
tuple 轉換為 list 比較簡單。
list((1, 2, 3)) # [1, 2, 3]
dict -> list
字典轉換列表,會取鍵名作為列表的值。
list({`name`: `hello`, `age`: 18}) # [`name`, `age`]
set -> list
集合轉換列表,會先去重為標準的集合數值,然後再轉換。
list({1, 2, 3, 3, 2, 1}) # [1, 2, 3]
tuple
與列表一樣,支援轉換為 tuple 的型別,只能是序列。
str -> tuple
tuple(`中國人`) # (`中`, `國`, `人`)
bytes -> tuple
bytes 轉換元組,會取每個位元組的 ASCII 十進位制值並組合成列表。
tuple(b`hello`) # (104, 101, 108, 108, 111)
list -> tuple
tuple([1, 2, 3]) # (1, 2, 3)
dict -> tuple
tuple({`name`: `hello`, `age`: 18}) # (`name`, `age`)
set -> tuple
tuple({1, 2, 3, 3, 2, 1}) # (1, 2, 3)
dict
str -> dict
-
使用 json 模組
使用 json 模組轉換 JSON 字串為字典時,需要求完全符合 JSON 規範,尤其注意鍵和值只能由單引號包裹,否則會報錯。
import json user_info = `{"name": "john", "gender": "male", "age": 28}` print(json.loads(user_info)) # {`name`: `john`, `gender`: `male`, `age`: 28}
-
使用 eval 函式
因為 eval 函式能執行任何符合語法的表示式字串,所以存在嚴重的安全問題,不建議。
user_info = "{`name`: `john`, `gender`: `male`, `age`: 28}" print(eval(user_info)) # {`name`: `john`, `gender`: `male`, `age`: 28}
-
使用 ast.literal_eval 方法
使用 ast.literal_eval 進行轉換既不存在使用 json 進行轉換的問題,也不存在使用 eval 進行轉換的 安全性問題,因此推薦使用 ast.literal_eval。
import ast user_info = "{`name`: `john`, `gender`: `male`, `age`: 28}" user_dict = ast.literal_eval(user_info) print(user_dict) # {`name`: `john`, `gender`: `male`, `age`: 28}
list -> dict
通過 zip 將 2 個列表對映為字典:
list1 = [1, 2, 3, 4]
list2 = [1, 2, 3]
print(dict(zip(list1, list2)))
# {1: 1, 2: 2, 3: 3}
將巢狀的列表轉換為字典:
li = [
[1, 111],
[2, 222],
[3, 333],
]
print(dict(li))
# {1: 111, 2: 222, 3: 333}
tuple -> dict
通過 zip 將 2 個元組對映為字典:
tp1 = (1, 2, 3)
tp2 = (1, 2, 3, 4)
print(dict(zip(tp1, tp2)))
# {1: 1, 2: 2, 3: 3}
將巢狀的元組轉換為字典:
tp = (
(1, 111),
(2, 222),
(3, 333),
)
print(dict(tp))
# {1: 111, 2: 222, 3: 333}
set -> dict
通過 zip 將 2 個集合對映為字典:
set1 = {1, 2, 3}
set2 = {`a`, `b`, `c`}
print(dict(zip(set1, set2)))
# {1: `c`, 2: `a`, 3: `b`}
set
str -> set
先將字元切割成元組,然後再去重轉換為集合。
print(set(`hello`)) # {`l`, `o`, `e`, `h`}
bytes -> set
會取每個位元組的 ASCII 十進位制值並組合成元組,再去重。
set(b`hello`) # {104, 108, 101, 111}
list -> set
先對列表去重,再轉換。
set([1, 2, 3, 2, 1]) # {1, 2, 3}
tuple -> set
先對列表去重,再轉換。
set((1, 2, 3, 2, 1)) # {1, 2, 3}
dict -> set
會取字典的鍵名組合成集合。
set({`name`: `hello`, `age`: 18})
# {`age`, `name`}
參考資料
原文地址: https://shockerli.net/post/py…
更多文章請訪問我的個人部落格: https://shockerli.net