Python有哪些常用的内置数据类型?

Python常用内置数据类型包括:整数(int)、浮点数(float)、复数(complex)、字符串(str)、列表(list)、元组(tuple)、字典(dict)、集合(set)、布尔值(bool)和空值(None)。这些类型分为可变(如list、dict、set)和不可变(如int、float、str、tuple、bool)两类,选择合适类型能提升代码效率与可维护性。列表用于有序可变序列,元组用于有序不可变序列,字典通过键值对实现高效查找,集合用于去重和成员检测,字符串处理文本且不可变,布尔值支持逻辑判断,None表示空值。理解可变性差异对函数参数传递、字典键使用及并发安全至关重要。高效操作包括列表推导式、字符串f-string格式化、字典get方法与推导式、集合运算等,合理运用可写出简洁高效的Python代码。

python有哪些常用的内置数据类型?

Python内置的数据类型是其强大和灵活的基础,它们是构建任何程序的核心。简单来说,我们日常开发中最常用到的有数字、字符串、列表、元组、字典和集合,以及用于逻辑判断的布尔值和表示“空”的NoneType。理解并熟练运用这些类型,是写出高效、可维护Python代码的第一步。

Python有哪些常用的内置数据类型?

说起Python的内置数据类型,这简直是老生常谈了,但每次深入思考,总能发现一些当初没太在意的小细节。对我个人而言,它们就像是编程世界的乐高积木,不同的形状和颜色,组合起来能搭出千变万化的结构。

首先是数字类型,这个最直观:

立即学习“Python免费学习笔记(深入)”;

整数(

int

:就是不带小数点的数字,比如

10

-5

。Python 3 里整数大小是无限的,内存够用就行,这和一些语言的固定位宽还挺不一样。浮点数(

float

:带小数点的数字,比如

3.14

-0.5

。这里有个小坑,浮点数计算可能会有精度问题,这是计算机二进制表示的固有特性,不是Python独有。复数(

complex

:由实部和虚部组成,比如

1 + 2j

。日常开发中可能不常用,但在科学计算领域,它就是常客了。

接着是字符串(

str

,这几乎是所有程序都离不开的:

用单引号、双引号或三引号括起来的文本序列,比如

'hello'

"world"

"""多行文本"""

。字符串在Python里是不可变的,这意味着你不能直接修改字符串的某个字符,每次操作都会生成新的字符串。这在处理文本时,比如日志分析、用户输入,简直是主力军。

然后是几个核心的集合类型,它们在组织数据上各有千秋:

列表(

list

:用方括号

[]

括起来,元素之间用逗号隔开,比如

[1, 'hello', 3.14]

。列表是有序的,而且是可变的。这意味着你可以随意添加、删除、修改其中的元素。在需要动态管理一组数据时,列表几乎是我的首选。比如记录一系列操作步骤,或者存储从数据库查询出来的多条记录。

my_list = [1, 2, 3]my_list.append(4) # [1, 2, 3, 4]my_list[0] = 0    # [0, 2, 3, 4]

元组(

tuple

:用圆括号

()

括起来,比如

(1, 'hello', 3.14)

。元组和列表很像,但它最大的特点是不可变。一旦创建,就不能修改。这让它在某些场景下比列表更安全,比如作为字典的键(因为字典的键必须是不可变类型),或者在函数返回多个值时,用元组打包返回,能确保返回的数据不会被外部随意篡改。

my_tuple = (1, 2, 3)# my_tuple[0] = 0 # 这会报错!

字典(

dict

:用花括号

{}

括起来,由键值对组成,比如

{'name': 'Alice', 'age': 30}

。字典提供了一种通过“键”来快速查找“值”的方式,效率非常高。在处理配置信息、API响应数据、或者任何需要通过唯一标识符访问数据的地方,字典简直是神器。Python 3.7+ 版本开始,字典会保持插入顺序,这在很多时候非常方便。

my_dict = {'a': 1, 'b': 2}print(my_dict['a']) # 输出 1my_dict['c'] = 3    # 添加新键值对

集合(

set

:也用花括号

{}

括起来,但只包含元素,没有键值对,比如

{1, 2, 3}

。集合最大的特点是元素不重复,而且是无序的。当你需要快速去重,或者进行数学上的集合操作(并集、交集、差集)时,集合是最佳选择。

my_set = {1, 2, 2, 3}print(my_set) # 输出 {1, 2, 3}

最后,还有两个非常重要的辅助类型:

布尔值(

bool

:只有

True

False

两个值。它是逻辑判断的基石,几乎所有条件语句和循环都离不开它。空值(

NoneType

:只有一个值

None

。它表示一个空对象,或者说“什么都没有”。在函数没有明确返回值时,默认返回

None

;或者在初始化一个变量,但暂时不想给它赋值时,用

None

也很常见。

Python数据类型在实际开发中如何选择和应用?

在实际项目里,选择合适的数据类型远不止是“哪个能用”那么简单,它直接关系到代码的效率、可读性和维护性。这就像你装修房子,螺丝刀和锤子都能把钉子敲进去,但用锤子显然更高效。

列表 vs. 元组:这是个经典问题。如果你需要一个有序的、元素可以随时增删改的序列,那毫无疑问是列表。比如用户提交的表单数据列表、待处理的任务队列。而当你需要一个有序的、但一旦创建就不能再修改的序列,比如函数返回的多个固定值(经纬度坐标

(lat, lon)

)、或者作为字典的键(因为字典的键必须是不可变类型),那就用元组。元组的不可变性也意味着它在某些场景下比列表更节省内存,并且可以被哈希(hashable)。

字典 vs. 列表(作为关联数组):当你需要通过一个唯一的标识符(键)来快速查找对应的数据(值)时,字典是最佳选择。比如存储用户信息

{'user_id': '123', 'name': '张三'}

,或者解析 JSON 格式的 API 响应。如果只是简单地存储一串有序的、可以通过索引访问的数据,并且这些数据之间没有明显的键值关联,那列表更合适。用列表模拟字典当然可以(比如

[['user_id', '123'], ['name', '张三']]

),但查找效率会低很多,代码也会更复杂。

集合用于去重和成员测试:如果你的核心需求是确保元素唯一性,或者需要高效地判断某个元素是否存在于一个大的数据集中,那么集合是无敌的。比如从日志文件中提取所有不重复的 IP 地址,或者判断一个用户是否属于某个权限组。集合的查找效率(平均 O(1))远高于列表(O(n)),对于大数据量尤其明显。

字符串处理:几乎所有涉及文本操作的地方都离不开字符串。从简单的拼接、格式化,到复杂的正则表达式匹配、文本解析,字符串的方法非常丰富。记住字符串的不可变性,这意味着频繁的字符串修改操作(比如在一个循环里反复拼接字符串)可能会创建大量临时字符串对象,导致性能下降。这时,考虑使用

str.join()

方法或者

io.StringIO

会更高效。

Python内置数据类型的“可变性”与“不可变性”有什么区别,为何重要?

理解Python数据类型的“可变性”(Mutable)和“不可变性”(Immutable)是掌握Python内存管理和避免一些隐晦 bug 的关键。这不仅仅是理论概念,它直接影响你代码的行为。

什么是可变性?一个可变(Mutable)的数据类型,意味着它在创建后,其内部状态(所包含的元素或值)可以被修改,而无需创建新的对象。修改操作会直接作用于原对象。

可变类型包括:

list

(列表)、

dict

(字典)、

set

(集合)

a = [1, 2, 3]b = a # b和a指向同一个列表对象b.append(4)print(a) # 输出 [1, 2, 3, 4],a也被修改了

这里

b.append(4)

修改的是

a

b

共同指向的那个列表对象,所以

a

的值也变了。

什么是不可变性?一个不可变(Immutable)的数据类型,意味着它在创建后,其内部状态就不能被修改。任何看似修改它的操作,实际上都会创建一个新的对象。

不可变类型包括:

int

(整数)、

float

(浮点数)、

str

(字符串)、`

tuple

(元组)、

bool

(布尔值)

x = 10y = x # y和x指向同一个整数对象y = y + 1 # 实际上是创建了一个新的整数对象11,并让y指向它print(x) # 输出 10,x的值没有变

在这个例子中,

y = y + 1

并没有修改

x

所指向的

10

这个对象,而是创建了一个新的整数对象

11

,然后让

y

指向了

11

x

仍然指向

10

为何重要?

函数参数传递:当可变对象作为函数参数传递时,函数内部对该对象的修改会影响到函数外部的原始对象。这可能是你想要的,也可能是导致难以追踪 bug 的源头。而不可变对象作为参数时,函数内部无法修改外部对象。

def modify_list(l):    l.append(4)my_list = [1, 2, 3]modify_list(my_list)print(my_list) # [1, 2, 3, 4]def modify_int(i):    i = i + 1 # 只是修改了函数内部的局部变量i    return imy_int = 10new_int = modify_int(my_int)print(my_int) # 10 (不变)print(new_int) # 11

字典的键(

dict

keys)和集合的元素(

set

elements):字典的键和集合的元素必须是不可变类型。这是因为字典和集合的底层实现依赖于元素的哈希值(hash value)来快速查找。如果键或元素是可变的,它们的哈希值可能会改变,导致无法正确查找。因此,列表和字典本身不能作为字典的键或集合的元素,但元组可以(只要元组内部的元素也是不可变的)。

并发编程:在多线程或多进程环境中,可变对象共享可能会引入竞态条件和同步问题,需要额外的锁机制来保护。不可变对象天生就是线程安全的,因为它们不会被修改。

性能:不可变对象在某些情况下可以进行优化,比如字符串的“interning”(字符串驻留),可以节省内存。

如何高效地操作和处理Python的常见数据类型?

掌握了数据类型,下一步就是如何高效地利用它们。Python提供了大量内置方法和语法糖,能让数据处理变得简洁而强大。

列表(

list

)的高效操作

列表推导式(List Comprehensions):这是Python处理列表的“杀手锏”。用一行代码就能创建新列表,或者对现有列表进行过滤、转换,效率和可读性都极高。

squares = [x**2 for x in range(10) if x % 2 == 0] # [0, 4, 16, 36, 64]

切片(Slicing):快速获取子列表,

my_list[start:end:step]

。这比循环遍历要快得多。

append()

extend()

append()

添加单个元素到列表末尾,

extend()

添加另一个可迭代对象的所有元素到列表末尾。

insert()

pop()

/

remove()

insert(index, element)

在指定位置插入,

pop(index)

移除并返回指定位置的元素(默认末尾),

remove(value)

移除第一个匹配的元素。排序

list.sort()

会原地修改列表,

sorted(list)

返回一个新的已排序列表。

字符串(

str

)的实用技巧

f-string(格式化字符串字面值):Python 3.6+ 引入,是目前最推荐的字符串格式化方式,简洁、直观、高效。

name = "Alice"age = 30greeting = f"Hello, {name}. You are {age} years old."

split()

join()

split()

将字符串按分隔符拆分成列表,

join()

将列表中的字符串元素用指定字符连接起来。这是处理文本文件、CSV 数据时最常用的组合。

sentence = "Hello world Python"words = sentence.split() # ['Hello', 'world', 'Python']new_sentence = "-".join(words) # "Hello-world-Python"

replace()

:替换字符串中的子串。

strip()

/

lstrip()

/

rstrip()

:移除字符串两端(或左、右)的空白字符。

字典(

dict

)的进阶用法

get(key, default_value)

:安全地获取字典值。如果键不存在,不会报错,而是返回

default_value

(默认为

None

)。这比直接

dict[key]

更健壮。

keys()

values()

items()

:分别返回字典的所有键、所有值、所有键值对的视图对象。这些视图对象是动态的,反映字典的最新状态。字典推导式(Dictionary Comprehensions):类似于列表推导式,快速创建或转换字典。

data = {'a': 1, 'b': 2}new_data = {k: v * 2 for k, v in data.items()} # {'a': 2, 'b': 4}

合并字典:Python 3.9+ 可以使用

|

运算符合并字典,更早版本可以使用

**

解包运算符。

dict1 = {'a': 1, 'b': 2}dict2 = {'c': 3, 'a': 4}merged_dict = dict1 | dict2 # {'a': 4, 'b': 2, 'c': 3} (dict2的'a'覆盖dict1的)

集合(

set

)的集合运算

union()

/

|

(并集):返回两个集合的所有元素。

intersection()

/

&

(交集):返回两个集合的共同元素。

difference()

/

-

(差集):返回在一个集合中但不在另一个集合中的元素。

symmetric_difference()

/

^

(对称差集):返回在两个集合中,但不同时在两个集合中的元素。

理解这些基本操作和它们背后的逻辑,能让你在面对各种数据处理任务时,迅速找到最Pythonic、最有效率的解决方案。别小看这些基础,它们是构建复杂系统的基石。

以上就是Python有哪些常用的内置数据类型?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1370059.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
利用 JAX vmap 高效并行化模型集成推理:解决参数结构不一致问题
上一篇 2025年12月14日 10:12:05
如何发布一个自己的Python包到PyPI?
下一篇 2025年12月14日 10:12:23

相关推荐

  • composer require-dev和require有什么不同_Composer Require与Require-Dev区别解析

    require用于声明项目运行必需的依赖,如框架、数据库组件和第三方SDK,这些包会随项目部署到生产环境;2. require-dev用于声明仅在开发和测试阶段需要的工具,如PHPUnit、PHPStan、Faker等,不会默认部署到生产环境;3. 安装时composer install根据环境决定…

    2026年5月10日
    1000
  • 修复Django电商项目中AJAX过滤产品列表图片不显示问题

    在Django电商项目中,当使用AJAX动态加载过滤后的产品列表时,常遇到图片无法正常显示的问题。这通常是由于前端模板中图片加载方式(如data-setbg属性结合JavaScript库)与AJAX动态内容更新机制不兼容所致。解决方案是直接在AJAX返回的HTML中使用标准的标签来渲染图片,确保浏览…

    2026年5月10日
    000
  • 开源免费PHP工具 PHP开发效率提升利器

    推荐开源免费PHP开发工具以提升效率:VS Code、Sublime Text轻量高效,PhpStorm专业强大;调试用Xdebug、Kint、Ray;依赖管理选Composer;代码质量工具包括PHPStan、Psalm、PHP_CodeSniffer;数据库管理可用%ignore_a_1%MyA…

    2026年5月10日
    000
  • Matplotlib 地图中多类型图例的创建与优化

    Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化

    本教程旨在解决matplotlib地图可视化中,如何在一个图例中同时展示颜色块(如区域分类)和自定义标记(如特定兴趣点)的问题。文章详细介绍了当传统`patch`对象无法正确显示标记时,如何利用`matplotlib.lines.line2d`创建标记图例句柄,并将其与颜色块图例句柄合并,从而生成一…

    2026年5月10日 用户投稿
    100
  • Golang JSON序列化:控制敏感字段暴露的最佳实践

    本教程探讨golang中如何高效控制结构体字段在json序列化时的可见性。当需要将包含敏感信息的结构体数组转换为json响应时,通过利用`encoding/json`包提供的结构体标签,特别是`json:”-“`,可以轻松实现对特定字段的忽略,从而避免敏感数据泄露,确保api…

    2026年5月10日
    000
  • 利用海象运算符简化条件赋值:Python教程与最佳实践

    本文旨在探讨Python中海象运算符(:=)在条件赋值场景下的应用。通过对比传统if/else语句与海象运算符,以及条件表达式,分析海象运算符在简化代码、提高可读性方面的优势与局限性。并通过具体示例,展示如何在列表推导式等场景下合理使用海象运算符,同时强调其潜在的复杂性及替代方案,帮助开发者更好地掌…

    2026年5月10日
    100
  • 比特币新手教程 比特币交易平台有哪些

    比特币是一种去中心化的数字货币,基于区块链技术实现点对点交易,具有匿名性、有限发行和不可篡改等特点;新手可通过交易所购买,P2P交易获得比特币,常用平台包括Binance、OKX和Huobi;交易流程包括注册账户、实名认证、绑定支付方式、充值法币并下单购买,可选择市价单或限价单;比特币存储方式有交易…

    2026年5月10日
    000
  • RichHandler与Rich Progress集成:解决显示冲突的教程

    在使用rich库的`richhandler`进行日志输出并同时使用`progress`组件时,可能会遇到显示错乱或溢出问题。这通常是由于为`richhandler`和`progress`分别创建了独立的`console`实例导致的。解决方案是确保日志处理器和进度条组件共享同一个`console`实例…

    2026年5月10日
    000
  • Golang goroutine与channel调试技巧

    使用go run -race检测数据竞争,结合runtime.NumGoroutine监控协程数量,通过pprof分析阻塞调用栈,利用select超时避免永久阻塞,有效排查goroutine泄漏、死锁和数据竞争问题。 Go语言的goroutine和channel是并发编程的核心,但它们也带来了调试上…

    2026年5月10日
    000
  • 使用 Jupyter Notebook 进行探索性数据分析

    Jupyter Notebook通过单元格实现代码与Markdown结合,支持数据导入(pandas)、清洗(fillna)、探索(matplotlib/seaborn可视化)、统计分析(describe/corr)和特征工程,便于记录与分享分析过程。 Jupyter Notebook 是进行探索性…

    2026年5月10日
    000
  • 《魔兽世界》将于6月11日开启国服回归技术测试

    《魔兽世界》将于6月11日开启国服回归技术测试《魔兽世界》将于6月11日开启国服回归技术测试《魔兽世界》将于6月11日开启国服回归技术测试《魔兽世界》将于6月11日开启国服回归技术测试

    《%ign%ignore_a_1%re_a_1%》官方宣布,将于6月11日开启国服回归技术测试,时间为7天,并称可以在6月内正式开服,玩家们可以访问官网下载战网客户端并预下载“巫妖王之怒”客户端,技术测试详情见下图。 WordAi WordAI是一个AI驱动的内容重写平台 53 查看详情 以上就是《…

    2026年5月10日 用户投稿
    200
  • php常量怎么用_PHP常量(define/const)定义与使用方法

    PHP中可通过define函数和const关键字定义常量,用于存储不可变值。define适用于全局作用域,支持动态名称和条件定义,如define(‘SITE_NAME’, ‘MyWebsite’);const在编译时生效,语法简洁但限制多,只能在类或全…

    2026年5月10日
    000
  • 如何在HTML中插入表单元素_HTML表单控件与输入类型使用指南

    HTML表单通过标签构建,包含action和method属性定义数据提交目标与方式,常用input类型如text、password、email等适配不同输入需求,配合label、required、placeholder提升可用性,结合textarea、select、button等控件实现完整交互,是…

    2026年5月10日
    100
  • 前端缓存策略与JavaScript存储管理

    根据数据特性选择合适的存储方式并制定清晰的读写与清理逻辑,能显著提升前端性能;合理运用Cookie、localStorage、sessionStorage、IndexedDB及Cache API,结合缓存策略与定期清理机制,可在保证用户体验的同时避免安全与性能隐患。 前端缓存和JavaScript存…

    2026年5月10日
    200
  • HTML5网页如何实现手势操作 HTML5网页移动端交互的处理技巧

    首先利用原生touch事件实现滑动判断,再通过preventDefault解决滚动冲突,接着引入Hammer.js处理复杂手势,最后通过优化点击区域、避免事件冲突和增加视觉反馈提升体验。 在移动端浏览器中,HTML5网页可以通过触摸事件实现手势操作,提升用户体验。虽然原生JavaScript提供了基…

    2026年5月10日
    000
  • 深入理解 Express.js 中 next() 参数的作用与中间件机制

    本文深入探讨 express.js 中间件函数中的 `next()` 参数。它负责将控制权传递给请求-响应周期中的下一个中间件或路由处理程序。文章将详细解释 `next()` 的工作原理、中间件的注册与执行顺序,以及不正确使用 `next()` 可能导致请求挂起的风险,并通过代码示例和实际应用场景,…

    2026年5月10日
    000
  • Python命令怎样使用profile分析脚本性能 Python命令性能分析的基础教程

    使用Python的cProfile模块分析脚本性能最直接的方式是通过命令行执行python -m cProfile your_script.py,它会输出每个函数的调用次数、总耗时、累积耗时等关键指标,帮助定位性能瓶颈;为进一步分析,可将结果保存为文件python -m cProfile -o ou…

    2026年5月10日
    000
  • Python递归函数追踪与性能考量:以序列打印为例

    本文深入探讨了Python中一种递归打印序列元素的方法,并着重演示了如何通过引入缩进参数来有效追踪递归函数的执行流程和参数变化。通过实际代码示例,文章揭示了递归调用可能带来的潜在性能开销,特别是对调用栈空间的需求,以及Python默认递归深度限制可能导致的错误,为读者提供了理解和优化递归算法的实用见…

    2026年5月10日
    000
  • python中zip函数详解 python多序列压缩zip函数应用场景

    zip函数的应用场景包括:1) 同时遍历多个序列,2) 合并多个列表的数据,3) 数据分析和科学计算中的元素运算,4) 处理csv文件,5) 性能优化。zip函数是一个强大的工具,能够简化代码并提高处理多个序列时的效率。 在Python中,zip函数是一个非常有用的工具,它能够将多个可迭代对象打包成…

    2026年5月10日
    000
  • JavaScript 动态菜单点击高亮效果实现教程

    本教程详细介绍了如何使用 JavaScript 实现动态菜单的点击高亮功能。通过事件委托和状态管理,当用户点击菜单项时,被点击项会高亮显示(绿色),同时其他菜单项恢复默认样式(白色)。这种方法避免了不必要的DOM操作,提高了性能和代码可维护性,确保了无论点击方向如何,功能都能稳定运行。 动态菜单高亮…

    2026年5月10日
    200

发表回复

登录后才能评论
关注微信