速战速决 Python - python 数据类型: 数据类型转换,解构

速战速决 Python https://github.com/webabcd/PythonSample
作者 webabcd

速战速决 Python - python 数据类型: 数据类型转换,解构

示例如下:

datatype/conversion.py

# python 数据类型转换

a = 1
b = 3.14
# 隐式转换,a 会被转换为 float 类型
c = a + b
print(c, type(c)) # 4.140000000000001 <class 'float'>

# 这个无法隐式转换的,会报错 can only concatenate str (not "int") to str
# print("123" + 123)
# 数字转换为字符串需要通过 str() 显示转换
print("123" + str(123)) # 123123

# 浮点型的显示转换
print(float("1")) # 1.0

# 整型的显示转换,取整数部分
print(int(1.2)) # 1
print(int(-1.2)) # -1
print(int("3")) # 3
# 注:无法像下面这样将其转换为整型,需要先将其转换为浮点型,然后再转为整型
# print(int("3.14"))

# 布尔型的显示转换
print(bool(1)) # True
print(bool(0)) # False
print(bool(-1.2)) # True

# 整型和字节之间的转换
i = 2048
# length 代表字节大小,byteorder 代表字节序(大端序就是高位字节存放在低地址端,低位字节存放在高地址端)
print(i.to_bytes(length=2, byteorder='big')) # 整型转字节。结果 b'\x08\x00'
print(i.to_bytes(length=2, byteorder='big').hex()) # 整型转字节后再转十六进制字符串。结果 0800
print(int(i.to_bytes(2, byteorder='big').hex(), 16)) # 整型转字节后再转十六进制字符串,然后再按照十六进制字符串解析为整型。结果 2048
print(int.from_bytes(bytes=i.to_bytes(length=2, byteorder='big'), byteorder='big')) # 整型转字节再转整型。结果 2048

# 字符串和字节之间的转换
print(b"xyz") # b'xyz'
print("xyz".encode()) # b'xyz'
print(b"xyz".decode()) # xyz

d = [1, 2, 3]
# 列表转换为集合
e = set(d) # {1, 2, 3}
print(e)
# 集合转换为列表
f = list(e) # [1, 2, 3]
print(f)
# 列表转换为元组
g = tuple(f) # (1, 2, 3)
print(g)
# 元组转换为列表
h = list(g) # [1, 2, 3]
print(h)

# json 字符串与字典表之间的转换
import json
dict = {"k1":"v1", "k2":"中文"}
# 通过 str() 将字典表转换为字符串是单引号的,不符合 json 规范
print(str(dict)) # {'k1': 'v1', 'k2': '中文'}
# 通过 json.dumps() 将字典表转换为 json 字符串,其是双引号的,符合 json 规范(默认,非 ascii 字符会被编码)
print(json.dumps(dict)) # {"k1": "v1", "k2": "\u4e2d\u6587"}
# 通过 json.dumps() 将字典表转换为 json 字符串,其是双引号的,符合 json 规范(避免 ascii 字符被编码)
print(json.dumps(dict, ensure_ascii=False)) # {"k1": "v1", "k2": "中文"}
# 通过 json.loads() 将 json 字符串转换为字典表
print(json.loads("{\"k\":\"v\"}")) # {'k': 'v'}



# python 解构

# 解构列表
i = [1, 2, 3]
i0, i1, i2 = i
print(i0) # 1
print(i1) # 2
print(i2) # 3

# 解构元组
j = (1, 2, 3)
j0, j1, j2 = j
print(j0) # 1
print(j1) # 2
print(j2) # 3

# 解构字典
k = {'name': 'webabcd', 'age': 43}
name, age = k.values()
print(name) # webabcd
print(age)  # 43

# 解构时通过 _ 忽略不需要的元素
l = [1, 2, 3, 4, 5]
l0, _, l2, _, l4 = l
print(l0) # 1
print(l2) # 3
print(l4) # 5

速战速决 Python https://github.com/webabcd/PythonSample
作者 webabcd

posted @ 2022-01-20 16:07  webabcd  阅读(74)  评论(0编辑  收藏  举报