目录

  • 一、元组类型内置方法(tuple)
    • 1.1 优先掌握(*****)
  • 二、元组和列表的区别


一、元组类型内置方法(tuple)

元组是不可变的列表,即元组的值不可更改,因此元组一般只用于只存不取的需求。也因此元组可以被列表取代掉,所以元组相比较列表使用的很少。元组相比较列表的优点为:列表的值修改后,列表的结构将会发生改变,而元组只需要存储,因此列表在某种程度上而言需要占用更多的内存。但是目前工业上内存已经不是问题了,所以工业上元组一般不会使用。

1.用途:多个装备、多个爱好、多门课程,甚至是多个女朋友

2.定义:在()内可以有多个任意类型的值,逗号分隔元素

# my_girl_friend = tuple(('jason','tank','sean'))my_girl_friend = ('jason', 'tank', 'sean')print(f"my_girl_friend: {my_girl_friend}")
my_girl_friend: ('jason', 'tank', 'sean')
name_str = ('egon')  # ()只是普通包含的意思name_tuple = ('egon',)print(f"type(name_str): {type(name_str)}")print(f"type(name_tuple): {type(name_tuple)}")
type(name_str): <class 'str'>type(name_tuple): <class 'tuple'>

3.常用操作+内置方法:常用操作和内置方法:

1.1 优先掌握(*****)

  1. 索引取值

  2. 切片(顾头不顾尾,步长)

  3. 长度len

  4. 成员运算in和not in

  5. 循环

  6. count

  7. index

1.索引取值

# tuple之索引取值name_tuple = ('nick', 'jason', 'tank', 'sean')# name_tuple[0] = 'nick handsom'  # 报错print(f"name_tuple[0]: {name_tuple[0]}")
name_tuple[0]: nick

2.切片(顾头不顾尾,步长)

# tuple之切片name_tuple = ('nick', 'jason', 'tank', 'sean')print(f"name_tuple[1:3:2]: {name_tuple[1:3:2]}")
name_tuple[1:3:2]: ('jason',)

3.长度

# tuple之长度name_tuple = ('nick', 'jason', 'tank', 'sean')print(f"len(name_tuple): {len(name_tuple)}")
len(name_tuple): 4

4.成员运算

# tuple之成员运算name_tuple = ('nick', 'jason', 'tank', 'sean')print(f"'nick' in name_tuple: {'nick' in name_tuple}")
'nick' in name_tuple: True

5.循环

# tuple之循环name_tuple = ('nick', 'jason', 'tank', 'sean')for name in name_tuple:    print(name)
nickjasontanksean

6.count()

# tuple之count()name_tuple = ('nick', 'jason', 'tank', 'sean')print(f"name_tuple.count('nick'): {name_tuple.count('nick')}")
name_tuple.count('nick'): 1

7.index()

# tuple之index()name_tuple = ('nick', 'jason', 'tank', 'sean')print(f"name_tuple.index('nick'): {name_tuple.index('nick')}")
name_tuple.index('nick'): 0

4.存一个值or多个值:多个值

5.有序or无序:有序

name_tuple = ('nick',)print(f'first:{id(name_tuple)}')
first:4394454152

6.可变or不可变:不可变数据类型

二、元组和列表的区别

l = ['a', 'b', 'c']print(f"id(l[0]): {id(l[0])}")l[0] = 'A'print(f"id(l[0]): {id(l[0])}")
id(l[0]): 4357367208id(l[0]): 4357775176

列表可变的原因是:索引所对应的值的内存地址是可以改变的

元组不可变得原因是:索引所对应的值的内存地址是不可以改变的,或者反过来说,只要索引对应值的内存地址没有改变,那么元组是始终没有改变的。

t1 = (['a', 'b', 'c'], 'wc', 'office')print(f"id(t1[0]): {id(t1[0])}")print(f"id(t1[1]): {id(t1[1])}")print(f"id(t1[2]): {id(t1[2])}")t1[0][0] = 'A'print(f"t1[0][0]: {t1[0][0]}")print(f"id(t1[0]): {id(t1[0])}")print(f"t1: {t1}")
id(t1[0]): 4394709960id(t1[1]): 4374626968id(t1[2]): 4394453568t1[0][0]: Aid(t1[0]): 4394709960t1: (['A', 'b', 'c'], 'wc', 'office')
©著作权归作者所有:来自51CTO博客作者wx5b1fd43180419的原创作品,如需转载,请注明出处,否则将追究法律责任

更多相关文章

  1. 【DB笔试面试49】在Oracle中,你需要创建索引提高薪水审查的性能,该
  2. 【DB笔试面试661】在Oracle中,在新建或重建索引时有哪些锁?
  3. 全文检索技术ElasticSearch使用
  4. 【DB笔试面试641】在Oracle中,新建索引后统计信息是否自动收集?
  5. 【DB笔试面试555】在Oracle中,全文索引的作用是什么?
  6. ElasticSearch实战系列四: ElasticSearch理论知识介绍
  7. MySQL覆盖索引(Covering Index)
  8. MySQL索引之哈希索引和自适应哈希索引(Adaptive Hash Index)
  9. MySQL 续集 02

随机推荐

  1. 读“rm -rf/ 又引发了一个血案”之触动
  2. Win10&Linux下Apache2+PHP7+Mysql安装以
  3. linux安装zabbix_agnetd-3.2.7
  4. OCaml编译错误:/ usr / bin / ld:找不到-ls
  5. Linux内存管理 - PAGE_OFFSET理解
  6. linux系统启动过程详解-开机加电后发生了
  7. Linux的五个文件查找命令:find,locate,whe
  8. linux下如何导出.txt文件?
  9. linux配置虚拟IP地址方法
  10. gcc常用命令介绍