博客
关于我
一文搞懂Python中的所有数组数据类型
阅读量:204 次
发布时间:2019-02-28

本文共 1340 字,大约阅读时间需要 4 分钟。

Python中的数组类型解析:从 list 到 bytes

在编程领域,数组是许多语言中最基础的数据结构。对于Python而言,提供了多种数组类型,每种类型都有其独特的特点和适用场景。本文将从多个维度对这些数组类型进行分析。


0x00 可变的动态列表 list

动态列表(list)是Python中最常用的数组类型。它的最大特点是可变性,支持动态扩容,并且可以存储Python中的一切对象。这种灵活性使其在开发中极为常用。

优点:

  • 多样性:可以存储任意Python对象。
  • 动态扩容:无需提前指定元素类型,支持实时增删改。

示例:

arr = ["one", "two", "three"]arr.append(4)  # 动态扩容del arr[2]    # 删除元素

0x01 不可变的 tuple

Tuple(元组)与list类似,但其最大特点是不可变性。一旦创建,元组的元素无法修改,也无法扩容。

优点:

  • 内存效率:占用内存空间较少。
  • 运算优化:适合需要频繁读取和并行操作的场景。

示例:

t = ('one', 'two', 3)t += (1,)   # 生成新元组tcopy = t + (1,)

0x02 array.array

如果需要操作低级别的数组,Python提供了array模块。与list和tuple不同,array数组可变性,但只能存储相同类型的数据。

优点:

  • 空间效率:内存占用较低。
  • 类型统一:只能存储特定类型的数据。

示例:

arr = array.array('f', [1.0, 1.5, 2.0, 2.5])arr.append(4.89)

0x03 字符串序列 str

在Python3中,str对象表示文本字符序列,其特点是不可变且支持Unicode字符。

优点:

  • 字符序列:每个元素都是字符串对象。
  • 不可变性:无法修改元素。

示例:

s = '123abc's[0]  # 获取字符sn = list(s)  # 转换为列表操作

0x04 bytes 和 bytearray

Bytes对象用于存储字节序列,bytearray则是可变的字节数组。两者在功能上有明显差异。

bytes(不可变字节数组)

  • 字节值范围为0-256。
  • 不支持动态修改操作。

bytearray(可变字节数组)

  • 可动态扩容。
  • 支持修改和删除操作。

示例:

ba = bytearray((1, 3, 5, 7, 9))ba.append(6)  # 添加元素

0x05 数据类型之间的转换

list 与 tuple

tuple_l = list(t)

str 与 list

l = list('abc')''.join(l)  # 转换为字符串

bytes 与 str

s = '123'b = s.encode('utf-8')  # 转换为字节序列

0x06 总结

在实际开发中,选择合适的数组类型至关重要。例如:

  • 如果需要动态管理数据,优先选择list或bytearray。
  • 如果需要高效的内存占用,使用array.array。
  • 如果需要存储文本或二进制数据,选择str或bytes。

了解这些数组类型的特点和用法,可以帮助开发者更高效地完成编程任务。

转载地址:http://pddp.baihongyu.com/

你可能感兴趣的文章
oracle 限制用户并行,insert /*parallel */ 到不同用户,并行起不来的问题
查看>>
oracle--用户,权限,角色的管理
查看>>
Oracle-定时任务-JOB
查看>>
oracle.dataaccess 连接池,asp.net使用Oracle.DataAccess.dll连接Oracle
查看>>
oracle00205报错,Oracle控制文件损坏报错场景
查看>>
Oracle10g EM乱码之快速解决
查看>>
Oracle10g下载地址--多平台下的32位和64位
查看>>
Oracle10g安装了11g的ODAC后,PL/SQL连接提示TNS:无法解析指定的连接标识符
查看>>
oracle11g dataguard物理备库搭建(关闭主库cp数据文件到备库)
查看>>
Oracle11G基本操作
查看>>
Oracle11g服务详细介绍及哪些服务是必须开启的?
查看>>
Oracle11g静默安装dbca,netca报错处理--直接跟换操作系统
查看>>
oracle12安装软件后安装数据库,然后需要自己配置监听
查看>>
Oracle——08PL/SQL简介,基本程序结构和语句
查看>>
Oracle——distinct的用法
查看>>
Oracle、MySQL、SQL Server架构大对比
查看>>
oracle下的OVER(PARTITION BY)函数介绍
查看>>
Oracle中DATE数据相减问题
查看>>
Oracle中merge into的使用
查看>>
oracle中sql查询上月、本月、上周、本周、昨天、今天的数据!
查看>>