Python常用内置数据类型有哪些?
小伙伴们有没有觉得学习文章很有意思?有意思就对了!今天就给大家带来《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内置的数据类型是其强大和灵活的基础,它们是构建任何程序的核心。简单来说,我们日常开发中最常用到的有数字、字符串、列表、元组、字典和集合,以及用于逻辑判断的布尔值和表示“空”的NoneType。理解并熟练运用这些类型,是写出高效、可维护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']) # 输出 1 my_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 = 10 y = 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 i my_int = 10 new_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)
返回一个新的已排序列表。
- 列表推导式(List Comprehensions):这是Python处理列表的“杀手锏”。用一行代码就能创建新列表,或者对现有列表进行过滤、转换,效率和可读性都极高。
字符串(
str
)的实用技巧:- f-string(格式化字符串字面值):Python 3.6+ 引入,是目前最推荐的字符串格式化方式,简洁、直观、高效。
name = "Alice" age = 30 greeting = 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()
:移除字符串两端(或左、右)的空白字符。
- f-string(格式化字符串字面值):Python 3.6+ 引入,是目前最推荐的字符串格式化方式,简洁、直观、高效。
字典(
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、最有效率的解决方案。别小看这些基础,它们是构建复杂系统的基石。
今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

- 上一篇
- QQ空间网页版登录入口及电脑登录方法

- 下一篇
- Linux查看时间命令:date使用教程
-
- 文章 · python教程 | 18分钟前 |
- Pythonlambda函数使用技巧详解
- 147浏览 收藏
-
- 文章 · python教程 | 26分钟前 |
- Python随机数生成全攻略
- 188浏览 收藏
-
- 文章 · python教程 | 1小时前 |
- Pythonpandas数据筛选技巧分享
- 261浏览 收藏
-
- 文章 · python教程 | 1小时前 |
- Pythonopenpyxl操作Excel教程
- 311浏览 收藏
-
- 文章 · python教程 | 1小时前 |
- Python轮子包怎么用?
- 471浏览 收藏
-
- 文章 · python教程 | 1小时前 |
- Scrapy多线程抓取技巧分享
- 383浏览 收藏
-
- 文章 · python教程 | 2小时前 |
- Python删除文件的简单方法有哪些?
- 283浏览 收藏
-
- 文章 · python教程 | 2小时前 |
- Pythoninput函数使用全解析
- 201浏览 收藏
-
- 文章 · python教程 | 2小时前 |
- PandasDataFrame修改特定文本方法
- 288浏览 收藏
-
- 文章 · python教程 | 2小时前 |
- Python中idx是什么意思?详解索引用法
- 482浏览 收藏
-
- 文章 · python教程 | 3小时前 |
- Turtle画网格教程:XY轴绘制详解
- 235浏览 收藏
-
- 文章 · python教程 | 4小时前 |
- 数字格式化不显科学计数法的方法
- 301浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 514次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 499次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- AI Mermaid流程图
- SEO AI Mermaid 流程图工具:基于 Mermaid 语法,AI 辅助,自然语言生成流程图,提升可视化创作效率,适用于开发者、产品经理、教育工作者。
- 391次使用
-
- 搜获客【笔记生成器】
- 搜获客笔记生成器,国内首个聚焦小红书医美垂类的AI文案工具。1500万爆款文案库,行业专属算法,助您高效创作合规、引流的医美笔记,提升运营效率,引爆小红书流量!
- 373次使用
-
- iTerms
- iTerms是一款专业的一站式法律AI工作台,提供AI合同审查、AI合同起草及AI法律问答服务。通过智能问答、深度思考与联网检索,助您高效检索法律法规与司法判例,告别传统模板,实现合同一键起草与在线编辑,大幅提升法律事务处理效率。
- 403次使用
-
- TokenPony
- TokenPony是讯盟科技旗下的AI大模型聚合API平台。通过统一接口接入DeepSeek、Kimi、Qwen等主流模型,支持1024K超长上下文,实现零配置、免部署、极速响应与高性价比的AI应用开发,助力专业用户轻松构建智能服务。
- 386次使用
-
- 迅捷AIPPT
- 迅捷AIPPT是一款高效AI智能PPT生成软件,一键智能生成精美演示文稿。内置海量专业模板、多样风格,支持自定义大纲,助您轻松制作高质量PPT,大幅节省时间。
- 380次使用
-
- Flask框架安装技巧:让你的开发更高效
- 2024-01-03 501浏览
-
- Django框架中的并发处理技巧
- 2024-01-22 501浏览
-
- 提升Python包下载速度的方法——正确配置pip的国内源
- 2024-01-17 501浏览
-
- Python与C++:哪个编程语言更适合初学者?
- 2024-03-25 501浏览
-
- 品牌建设技巧
- 2024-04-06 501浏览