百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

Python 数据转换详解

liuian 2025-05-30 16:04 19 浏览

数据转换是编程中非常重要的操作,Python 提供了多种方式来实现不同类型之间的转换。下面我将详细讲解 Python 中的各种数据转换方法。

一、基本数据类型转换

1. 数字类型之间的转换

# 整数转浮点数
num_int = 10
num_float = float(num_int)  # 10.0

# 浮点数转整数(会截断小数部分)
num_float = 3.14
num_int = int(num_float)  # 3

# 布尔值转数字
bool_true = True
num_from_bool = int(bool_true)  # 1

bool_false = False
num_from_bool = int(bool_false)  # 0

2. 字符串与数字的转换

# 字符串转整数
str_num = "123"
int_num = int(str_num)  # 123

# 字符串转浮点数
str_float = "3.14"
float_num = float(str_float)  # 3.14

# 数字转字符串
num = 42
str_num = str(num)  # "42"

# 注意:无效转换会引发 ValueError
try:
    invalid = int("hello")
except ValueError as e:
    print(f"错误: {e}")

3. 布尔值转换

# 其他类型转布尔
# 以下会转换为 False
print(bool(0))      # False
print(bool(0.0))    # False
print(bool(""))     # False
print(bool([]))     # False
print(bool({}))     # False
print(bool(None))   # False

# 其他值通常转换为 True
print(bool(1))      # True
print(bool(-1))     # True
print(bool(" "))    # True
print(bool([1]))    # True

二、容器类型转换

1. 列表(list)与其他容器的转换

# 元组转列表
my_tuple = (1, 2, 3)
my_list = list(my_tuple)  # [1, 2, 3]

# 集合转列表
my_set = {1, 2, 3}
my_list = list(my_set)  # [1, 2, 3](顺序可能不同)

# 字典转列表(默认获取键)
my_dict = {'a': 1, 'b': 2}
key_list = list(my_dict)  # ['a', 'b']
value_list = list(my_dict.values())  # [1, 2]
item_list = list(my_dict.items())  # [('a', 1), ('b', 2)]

# 字符串转列表
my_str = "hello"
char_list = list(my_str)  # ['h', 'e', 'l', 'l', 'o']

2. 元组(tuple)转换

# 列表转元组
my_list = [1, 2, 3]
my_tuple = tuple(my_list)  # (1, 2, 3)

# 集合转元组
my_set = {1, 2, 3}
my_tuple = tuple(my_set)  # (1, 2, 3)(顺序可能不同)

# 字典转元组
my_dict = {'a': 1, 'b': 2}
key_tuple = tuple(my_dict)  # ('a', 'b')

3. 集合(set)转换

# 列表转集合(自动去重)
my_list = [1, 2, 2, 3]
my_set = set(my_list)  # {1, 2, 3}

# 字符串转集合
my_str = "hello"
char_set = set(my_str)  # {'h', 'e', 'l', 'o'}(去重且无序)

4. 字典(dict)转换

# 键值对列表转字典
pairs = [('a', 1), ('b', 2)]
my_dict = dict(pairs)  # {'a': 1, 'b': 2}

# 两个列表转字典(使用zip)
keys = ['a', 'b']
values = [1, 2]
my_dict = dict(zip(keys, values))  # {'a': 1, 'b': 2}

# 字典推导式
my_dict = {k: v for k, v in pairs}  # {'a': 1, 'b': 2}

三、高级数据转换

1. 进制转换

# 十进制转其他进制字符串
num = 255
print(bin(num))  # '0b11111111'(二进制)
print(oct(num))  # '0o377'(八进制)
print(hex(num))  # '0xff'(十六进制)

# 其他进制字符串转十进制
print(int('0b11111111', 2))  # 255
print(int('0o377', 8))      # 255
print(int('0xff', 16))      # 255

2. ASCII码转换

# 字符转ASCII码
print(ord('A'))  # 65

# ASCII码转字符
print(chr(65))   # 'A'

3. 字节(bytes)转换

# 字符串转字节
my_str = "hello"
byte_data = my_str.encode('utf-8')  # b'hello'

# 字节转字符串
new_str = byte_data.decode('utf-8')  # 'hello'

# 整数列表转字节
int_list = [65, 66, 67]
byte_data = bytes(int_list)  # b'ABC'

4. JSON转换

import json

# Python对象转JSON字符串
data = {'name': 'Alice', 'age': 25}
json_str = json.dumps(data)  # '{"name": "Alice", "age": 25}'

# JSON字符串转Python对象
new_data = json.loads(json_str)  # {'name': 'Alice', 'age': 25}

四、自定义对象转换

1. 实现__str__和__repr__

class Person:
    def __init__(self, name, age):
        self.name = name
        self.age = age
    
    def __str__(self):
        return f"Person(name={self.name}, age={self.age})"
    
    def __repr__(self):
        return f"Person('{self.name}', {self.age})"

p = Person("Alice", 25)
print(str(p))   # Person(name=Alice, age=25)
print(repr(p))  # Person('Alice', 25)

2. 实现转换方法

class Temperature:
    def __init__(self, celsius):
        self.celsius = celsius
    
    def to_fahrenheit(self):
        return (self.celsius * 9/5) + 32

temp = Temperature(100)
print(temp.to_fahrenheit())  # 212.0

五、注意事项

类型安全:转换前最好检查类型或使用try-except处理可能的异常

try:
    num = int("123a")
except ValueError:
    print("无法转换为整数")

精度丢失:浮点数转整数会截断小数部分

print(int(3.99))  # 3(不是4)

隐式转换:某些操作会自动进行类型转换

print(1 + 2.0)  # 3.0(整数自动转为浮点数)

不可逆转换:某些转换会丢失信息且不可逆

original = [1, 2, 2, 3]
converted = set(original)  # {1, 2, 3}
# 无法恢复原始列表的顺序和重复元素

一看就会,一写就废,你学废了吗?

相关推荐

总结下SpringData JPA 的常用语法

SpringDataJPA常用有两种写法,一个是用Jpa自带方法进行CRUD,适合简单查询场景、例如查询全部数据、根据某个字段查询,根据某字段排序等等。另一种是使用注解方式,@Query、@Modi...

解决JPA在多线程中事务无法生效的问题

在使用SpringBoot2.x和JPA的过程中,如果在多线程环境下发现查询方法(如@Query或findAll)以及事务(如@Transactional)无法生效,通常是由于S...

PostgreSQL系列(一):数据类型和基本类型转换

自从厂子里出来后,数据库的主力就从Oracle变成MySQL了。有一说一哈,贵确实是有贵的道理,不是开源能比的。后面的工作里面基本上就是主MySQL,辅MongoDB、ES等NoSQL。最近想写一点跟...

基于MCP实现text2sql

目的:基于MCP实现text2sql能力参考:https://blog.csdn.net/hacker_Lees/article/details/146426392服务端#选用开源的MySQLMCP...

ORACLE 错误代码及解决办法

ORA-00001:违反唯一约束条件(.)错误说明:当在唯一索引所对应的列上键入重复值时,会触发此异常。ORA-00017:请求会话以设置跟踪事件ORA-00018:超出最大会话数ORA-00...

从 SQLite 到 DuckDB:查询快 5 倍,存储减少 80%

作者丨Trace译者丨明知山策划丨李冬梅Trace从一开始就使用SQLite将所有数据存储在用户设备上。这是一个非常不错的选择——SQLite高度可靠,并且多种编程语言都提供了广泛支持...

010:通过 MCP PostgreSQL 安全访问数据

项目简介提供对PostgreSQL数据库的只读访问功能。该服务器允许大型语言模型(LLMs)检查数据库的模式结构,并执行只读查询操作。核心功能提供对PostgreSQL数据库的只读访问允许L...

发现了一个好用且免费的SQL数据库工具(DBeaver)

缘起最近Ai不是大火么,想着自己也弄一些开源的框架来捣腾一下。手上用着Mac,但Mac都没有显卡的,对于学习Ai训练模型不方便,所以最近新购入了一台4090的拯救者,打算用来好好学习一下Ai(呸,以上...

微软发布.NET 10首个预览版:JIT编译器再进化、跨平台开发更流畅

IT之家2月26日消息,微软.NET团队昨日(2月25日)发布博文,宣布推出.NET10首个预览版更新,重点改进.NETRuntime、SDK、libraries、C#、AS...

数据库管理工具Navicat Premium最新版发布啦

管理多个数据库要么需要使用多个客户端应用程序,要么找到一个可以容纳你使用的所有数据库的应用程序。其中一个工具是NavicatPremium。它不仅支持大多数主要的数据库管理系统(DBMS),而且它...

50+AI新品齐发,微软Build放大招:拥抱Agent胜算几何?

北京时间5月20日凌晨,如果你打开微软Build2025开发者大会的直播,最先吸引你的可能不是一场原本属于AI和开发者的技术盛会,而是开场不久后的尴尬一幕:一边是几位微软员工在台下大...

揭秘:一条SQL语句的执行过程是怎么样的?

数据库系统能够接受SQL语句,并返回数据查询的结果,或者对数据库中的数据进行修改,可以说几乎每个程序员都使用过它。而MySQL又是目前使用最广泛的数据库。所以,解析一下MySQL编译并执行...

各家sql工具,都闹过哪些乐子?

相信这些sql工具,大家都不陌生吧,它们在业内绝对算得上第一梯队的产品了,但是你知道,他们都闹过什么乐子吗?首先登场的是Navicat,这款强大的数据库管理工具,曾经让一位程序员朋友“火”了一把。Na...

详解PG数据库管理工具--pgadmin工具、安装部署及相关功能

概述今天主要介绍一下PG数据库管理工具--pgadmin,一起来看看吧~一、介绍pgAdmin4是一款为PostgreSQL设计的可靠和全面的数据库设计和管理软件,它允许连接到特定的数据库,创建表和...

Enpass for Mac(跨平台密码管理软件)

还在寻找密码管理软件吗?密码管理软件有很多,但是综合素质相当优秀且完全免费的密码管理软件却并不常见,EnpassMac版是一款免费跨平台密码管理软件,可以通过这款软件高效安全的保护密码文件,而且可以...