摘要:支持转换为类型的,仅有,其他类型均不支持。如果中含有正负号数字和小数点以外的字符,则不支持转换。转换时,会自动添加虚数部分并以表示。转换会直接完全转换。转换列表,会取每个字节的十进制值并组合成列表转换为比较简单。
int
支持转换为 int 类型的,仅有 float、str、bytes,其他类型均不支持。
float -> int会去掉小数点及后面的数值,仅保留整数部分。
int(-12.94) # -12str -> int
如果字符串中有数字(0-9)和正负号(+/-)以外的字符,就会报错。
int("1209") # 1209 int("-12") # -12 int("+1008") # 1008bytes -> int
如果 bytes 中有数字(0-9)和正负号(+/-)以外的字符,就会报错。
int(b"1209") # 1209 int(b"-12") # -12 int(b"+1008") # 1008float
支持转换为 float 类型的,仅有 int、str、bytes,其他类型均不支持。
int -> floatint 转换为 float 时,会自动给添加一位小数。
float(-1209) # -1209.0str -> float
如果字符串含有正负号(+/-)、数字(0-9)和小数点(.)以外的字符,则不支持转换。
float("-1209") # -1209.0 float("-0120.29023") # -120.29023bytes -> float
如果 bytes 中含有正负号(+/-)、数字(0-9)和小数点(.)以外的字符,则不支持转换。
float(b"-1209") # -1209.0 float(b"-0120.29023") # -120.29023complex
仅支持 int、float、str 转换成 complex 类型。
int -> complexint 转换 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 -> strint 转换 str 会直接完全转换。
str(12) # 12float -> str
float 转换 str 会去除末位为 0 的小数部分。
str(-12.90) # -12.9complex -> 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"]) # abctuple -> str
会先将值格式化为标准的 tuple 表达式,然后再转换为字符串。
str(()) # () str((1, 2, 3)) # (1, 2, 3) "".join(("a", "b", "c")) # abcdict -> str
会先将值格式化为标准的 dict 表达式,然后再转换为字符串。
str({"name": "hello", "age": 18}) # {"name": "hello", "age": 18} str({}) # {} "".join({"name": "hello", "age": 18}) # nameageset -> 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 -> listlist("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 -> tupletuple("中国人") # ("中", "国", "人")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
摘要:文件夹主要建立以下文件夹存放一些网站常用的图片存放一些文件存放一些文件存放一些源文件存放所有临时图片和其它文件版权信息可选说明文件统一命名注本命名规则只适合物制作模式下文件统一放在文件夹下命名主样式定义链接样式定义白色黑色蓝色等等说明如有重文件夹主要建立以下文件夹: 1、Images 存放一些网站常用的图片; 2、Css 存放一些CSS文件; 3、Flash 存放一些Flash文件; ...
摘要:大家好,我是冰河有句话叫做投资啥都不如投资自己的回报率高。马上就十一国庆假期了,给小伙伴们分享下,从小白程序员到大厂高级技术专家我看过哪些技术类书籍。 大家好,我是...
摘要:层确保数据一致性和可靠性。保证集群的相关组件在同一时刻能够达成一致,相当于集群的领导层,负责收集更新和发布集群信息。元数据服务器,跟踪文件层次结构并存储只供使用的元数据。启迪云-高级开发工程师 侯玉彬前言上一次简单的介绍Ceph的过去和未来的发展。这一节将详细介绍Ceph的构件以及组件。Ceph存储架构Ceph 存储集群由几个不同的daemon组成,每个daemon负责Ceph 的一个独特...
阅读 2770·2021-11-22 14:44
阅读 506·2021-11-22 12:00
阅读 3644·2019-08-30 15:54
阅读 1528·2019-08-29 17:15
阅读 1860·2019-08-29 13:50
阅读 1071·2019-08-29 13:17
阅读 3482·2019-08-29 13:05
阅读 1157·2019-08-29 11:31