资讯专栏INFORMATION COLUMN

史上最全的 Python 3 类型转换指南

libxd / 962人阅读

摘要:支持转换为类型的,仅有,其他类型均不支持。如果中含有正负号数字和小数点以外的字符,则不支持转换。转换时,会自动添加虚数部分并以表示。转换会直接完全转换。转换列表,会取每个字节的十进制值并组合成列表转换为比较简单。

int

支持转换为 int 类型的,仅有 floatstrbytes,其他类型均不支持。

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 类型的,仅有 intstrbytes,其他类型均不支持。

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

仅支持 intfloatstr 转换成 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)                # ,转换内置类
str(hex)                # ,转换内置函数

转换类实例:

class Hello:
    pass


obj = Hello()

print(str(obj))

# <__main__.Hello object at 0x1071c6630>

转换函数:

def hello():
    pass


print(str(hello))

# 
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"}
参考资料

Python 如何将字符串转为字典


原文地址: https://shockerli.net/post/py...

更多文章请访问我的个人博客: https://shockerli.net

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/42049.html

相关文章

  • 史上最全JS文章

    摘要:路径由零或多个符号隔开的字符串,一般用来表示主机上的一个目录或文件地址。 JS高级与进阶 目录====================== 基础 2 Web API 45 面向对象编程 170 案例:贪吃蛇 179 继承 179 函数进阶 223 正则表达式 284 目录====================== 1.基础 1.1.变量声...

    junbaor 评论0 收藏0
  • 史上最全HTML和CSS标签常用命名规则

    摘要:文件夹主要建立以下文件夹存放一些网站常用的图片存放一些文件存放一些文件存放一些源文件存放所有临时图片和其它文件版权信息可选说明文件统一命名注本命名规则只适合物制作模式下文件统一放在文件夹下命名主样式定义链接样式定义白色黑色蓝色等等说明如有重文件夹主要建立以下文件夹:  1、Images 存放一些网站常用的图片;  2、Css 存放一些CSS文件;  3、Flash 存放一些Flash文件; ...

    番茄西红柿 评论0 收藏0
  • 从小白程序员一路晋升为大厂高级技术专家我看过哪些书籍?(建议收藏)

    摘要:大家好,我是冰河有句话叫做投资啥都不如投资自己的回报率高。马上就十一国庆假期了,给小伙伴们分享下,从小白程序员到大厂高级技术专家我看过哪些技术类书籍。 大家好,我是...

    sf_wangchong 评论0 收藏0
  • 技术栈:史上最全Ceph构件及组件分析

    摘要:层确保数据一致性和可靠性。保证集群的相关组件在同一时刻能够达成一致,相当于集群的领导层,负责收集更新和发布集群信息。元数据服务器,跟踪文件层次结构并存储只供使用的元数据。启迪云-高级开发工程师  侯玉彬前言上一次简单的介绍Ceph的过去和未来的发展。这一节将详细介绍Ceph的构件以及组件。Ceph存储架构Ceph 存储集群由几个不同的daemon组成,每个daemon负责Ceph 的一个独特...

    big_cat 评论0 收藏0

发表评论

0条评论

libxd

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<