总结分析列表、元组、字典、集合的相同与区别之处,只有彻底分清之后,就会在应用的时候,得心应手。

四句话总结

  • 列表是一个有序且可更改的集合,允许重复成员。
  • 元组是一个有序且不可更改的集合,允许重复成员。
  • 集合是一个无序、不可更改*且未索引的集合,没有重复成员。
  • 字典是一个有序且可更改的集合,没有重复成员。

公有的部分

获取长度,使用len()

要确定列表中有多少项,请使用len()函数

thislist = ["apple", "banana", "cherry"]
print(len(thislist))

要确定一个元组有多少项,请使用len()函数

thistuple = ("apple", "banana", "cherry")
print(len(thistuple))

要确定一个集合有多少项,请使用len()函数。

thisset = {"apple", "banana", "cherry"}

print(len(thisset))

要确定字典有多少项,请使用len()函数

thisdict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964,
"year": 2020
}
print(len(thisdict))

通过引用索引号来访问

列表项已编制索引,您可以通过引用索引号来访问它们

thislist = ["apple", "banana", "cherry"]
print(thislist[1])

您可以通过引用方括号内的索引号来访问元组项

thistuple = ("apple", "banana", "cherry")
print(thistuple[1])

是否存在指定项,请使用in关键字

要确定列表中是否存在指定项,请使用in关键字

thislist = ["apple", "banana", "cherry"]
if "apple" in thislist:
print("Yes, 'apple' is in the fruits list")

要确定元组中是否存在指定项,请使用in关键字

thistuple = ("apple", "banana", "cherry")
if "apple" in thistuple:
print("Yes, 'apple' is in the fruits tuple")

检查集合中是否有“香蕉”

thisset = {"apple", "banana", "cherry"}

print("banana" in thisset)

要确定字典中是否存在指定的键,请使用in关键字

thisdict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
}
if "model" in thisdict:
print("Yes, 'model' is one of the keys in the thisdict dictionary")

可以使用for循环遍历

可以使用for循环遍历列表项

thislist = ["apple", "banana", "cherry"]
for x in thislist:
print(x)

可以使用for循环遍历元组项

thistuple = ("apple", "banana", "cherry")
for x in thistuple:
print(x)

在集合中循环,并打印值

thisset = {"apple", "banana", "cherry"}

for x in thisset:
print(x)

循环字典

for x in thisdict:
print(thisdict[x])

还可以使用values()方法返回字典的值

for x in thisdict.values():
print(x)

可以使用keys()方法返回字典的键

for x in thisdict.keys():
print(x)

使用items()方法循环遍历键和值

for x, y in thisdict.items():
print(x, y)

clear()方法清空

clear()方法清空列表。

thislist = ["apple", "banana", "cherry"]
thislist.clear()
print(thislist)

clear()方法清空集合

thisset = {"apple", "banana", "cherry"}

thisset.clear()

print(thisset)

clear()方法清空字典

thisdict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
}
thisdict.clear()
print(thisdict)

del关键字

del关键字还会删除指定的索引

thislist = ["apple", "banana", "cherry"]
del thislist[0]
print(thislist)

del关键字也可以完全删除列表。

thislist = ["apple", "banana", "cherry"]
del thislist

del关键字将完全删除集合

thisset = {"apple", "banana", "cherry"}

del thisset

print(thisset)

del关键字删除字典具有指定键名的项

thisdict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
}
del thisdict["model"]
print(thisdict)

remove()方法

remove()方法删除指定的项。

thislist = ["apple", "banana", "cherry"]
thislist.remove("banana")
print(thislist)

要删除集合中的项,请使用remove()或discard()方法。

thisset = {"apple", "banana", "cherry"}

thisset.remove("banana")

print(thisset)

pop()方法

pop()方法删除列表指定的索引。

thislist = ["apple", "banana", "cherry"]
thislist.pop(1)
print(thislist)

您也可以使用pop()方法删除一个项目,但此方法将删除最后一个项目。请记住,集合是无序的,因此您将不知道删除了哪些项

thisset = {"apple", "banana", "cherry"}

x = thisset.pop()

print(x)

print(thisset)

pop()方法移除字典具有指定键名的项

thisdict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
}
thisdict.pop("model")
print(thisdict)

列表

insert()方法在指定的索引处插入项

thislist = ["apple", "banana", "cherry"]
thislist.insert(2, "watermelon")
print(thislist)

要将项目添加到列表的末尾,请使用append()方法

thislist = ["apple", "banana", "cherry"]
thislist.append("orange")
print(thislist)

要将其他列表中的元素附加到当前列表,请使用extend()方法。

thislist = ["apple", "banana", "cherry"]
tropical = ["mango", "pineapple", "papaya"]
thislist.extend(tropical)
print(thislist)

extend()方法不必附加列表,您可以添加任何可迭代对象(元组、集合、字典等)。

thislist = ["apple", "banana", "cherry"]
thistuple = ("kiwi", "orange")
thislist.extend(thistuple)
print(thislist)

如果不指定索引,则pop()方法将删除最后一项。

thislist = ["apple", "banana", "cherry"]
thislist.pop()
print(thislist)

列表理解提供了循环列表的最短语法:newlist = [*expression* for *item* in *iterable* if *condition* == True]

thislist = ["apple", "banana", "cherry"]
[print(x) for x in thislist]
fruits = ["apple", "banana", "cherry", "kiwi", "mango"]

newlist = [x for x in fruits if "a" in x]

print(newlist)
newlist = [x.upper() for x in fruits]

列表对象有一个sort()方法,默认情况下,该方法将按字母数字升序对列表进行排序

thislist = ["orange", "mango", "kiwi", "pineapple", "banana"]
thislist.sort()
print(thislist)

在排序列表时,我们可以使用内置函数作为关键函数

thislist = ["banana", "Orange", "Kiwi", "cherry"]
thislist.sort(key = str.lower)
print(thislist)

reverse()方法反转元素的当前排序顺序。

thislist = ["banana", "Orange", "Kiwi", "cherry"]
thislist.reverse()
print(thislist)

有多种方法可以复制,一种方法是使用内置的列表方法copy()。

您不能简单地通过键入list2=list1复制列表,因为:list2仅仅是对list1的引用,并且在list1中所做的更改也将自动在list2中进行。

thislist = ["apple", "banana", "cherry"]
mylist = thislist.copy()
print(mylist)

制作副本的另一种方法是使用内置方法list()。

thislist = ["apple", "banana", "cherry"]
mylist = list(thislist)
print(mylist)

在Python中,有几种方法可以连接或串联两个或多个列表。最简单的方法之一是使用+运算符。

list1 = ["a", "b", "c"]
list2 = [1, 2, 3] list3 = list1 + list2
print(list3)

也可以使用extend()方法,其目的是将元素从一个列表添加到另一个列表

list1 = ["a", "b" , "c"]
list2 = [1, 2, 3] list1.extend(list2)
print(list1)

元组

要创建只有一个项的元组,必须在该项后添加逗号,否则Python将无法将其识别为元组。

thistuple = ("apple",)
print(type(thistuple)) #NOT a tuple
thistuple = ("apple")
print(type(thistuple))

您可以将元组转换为列表,更改列表,然后将列表转换回元组。

x = ("apple", "banana", "cherry")
y = list(x)
y[1] = "kiwi"
x = tuple(y) print(x)

将元组添加到元组。您可以将元组添加到元组中,因此如果要添加一个(或多个)项,请使用该项创建一个新元组,并将其添加到现有元组中.

thistuple = ("apple", "banana", "cherry")
y = ("orange",)
thistuple += y print(thistuple)

我们可以将值提取回变量中,这称为“拆包”

fruits = ("apple", "banana", "cherry")

(green, yellow, red) = fruits

print(green)
print(yellow)
print(red)

如果变量的数量小于值的数量,则可以在变量名中添加*号,这些值将作为列表分配给变量

fruits = ("apple", "banana", "cherry", "strawberry", "raspberry")

(green, yellow, *red) = fruits

print(green)
print(yellow)
print(red)

要连接两个或多个元组,可以使用+运算符

tuple1 = ("a", "b" , "c")
tuple2 = (1, 2, 3) tuple3 = tuple1 + tuple2
print(tuple3)

如果要将元组的内容乘以给定的次数,可以使用*运算符

fruits = ("apple", "banana", "cherry")
mytuple = fruits * 2 print(mytuple)

集合

创建集后,不能更改其项,但可以添加新项。

thisset = {"apple", "banana", "cherry"}

thisset.add("orange")
print(thisset)

要将其他集合中的项添加到当前集合中,请使用update()方法。

thisset = {"apple", "banana", "cherry"}
tropical = {"pineapple", "mango", "papaya"} thisset.update(tropical) print(thisset)

可以使用union()方法返回包含两个集合中所有项的新集合,也可以使用update()方法将一个集合中的所有项插入另一个集合

set1 = {"a", "b" , "c"}
set2 = {1, 2, 3} set3 = set1.union(set2)
print(set3)
set1 = {"a", "b" , "c"}
set2 = {1, 2, 3} set1.update(set2)
print(set1)

intersection_update()方法将只保留两个集合中存在的项。

x = {"apple", "banana", "cherry"}
y = {"google", "microsoft", "apple"} x.intersection_update(y) print(x)

intersection()方法将返回一个新的集合,该集合只包含两个集合中存在的项。

x = {"apple", "banana", "cherry"}
y = {"google", "microsoft", "apple"} z = x.intersection(y) print(z)

symmetric_difference_update()方法将只保留两个集合中不存在的元素。

x = {"apple", "banana", "cherry"}
y = {"google", "microsoft", "apple"} x.symmetric_difference_update(y) print(x)

symmetric_difference()方法将返回一个新的集合,该集合只包含两个集合中不存在的元素。

x = {"apple", "banana", "cherry"}
y = {"google", "microsoft", "apple"} z = x.symmetric_difference(y) print(z)

字典

您可以通过在方括号内引用字典的键名来访问字典的项

thisdict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
}
x = thisdict["model"]

还有一个名为get()的方法,它将给出相同的结果

x = thisdict.get("model")

keys()方法将返回字典中所有键的列表。

x = thisdict.keys()

values()方法将返回字典中所有值的列表。

x = thisdict.values()

items()方法将返回字典中的每个项,作为列表中的元组。

x = thisdict.items()

返回的列表是字典项的视图,这意味着对字典所做的任何更改都将反映在项列表中。

car = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
} x = car.items() print(x) #before the change car["year"] = 2020 print(x) #after the change

popitem()方法删除最后插入的项(在3.7之前的版本中,将删除随机项)

thisdict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
}
thisdict.popitem()
print(thisdict)

您不能简单地通过键入dict2=dict1来复制字典,因为:dict2将仅是对dict1的引用,在dict1中所做的更改也将自动在dict2中进行。

thisdict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
}
mydict = thisdict.copy()
print(mydict)

字典可以包含字典,这称为嵌套字典。

myfamily = {
"child1" : {
"name" : "Emil",
"year" : 2004
},
"child2" : {
"name" : "Tobias",
"year" : 2007
},
"child3" : {
"name" : "Linus",
"year" : 2011
}
}
child1 = {
"name" : "Emil",
"year" : 2004
}
child2 = {
"name" : "Tobias",
"year" : 2007
}
child3 = {
"name" : "Linus",
"year" : 2011
} myfamily = {
"child1" : child1,
"child2" : child2,
"child3" : child3
}

您的关注,是我的无限动力!

公众号 @生活处处有BUG

Python入门系列(四)别再傻傻分不清:列表、元组、字典、集合的区别的更多相关文章

  1. python中列表 元组 字典 集合的区别

    列表 元组 字典 集合的区别是python面试中最常见的一个问题.这个问题虽然很基础,但确实能反映出面试者的基础水平. (1)列表 什么是列表呢?我觉得列表就是我们日常生活中经常见到的清单.比如,统计 ...

  2. python 中列表 元组 字典 集合的区别

    先看图片解释 (1)列表 什么是列表呢?我觉得列表就是我们日常生活中经常见到的清单.比如,统计过去一周我们买过的东西,把这些东西列出来,就是清单.由于我们买一种东西可能不止一次,所以清单中是允许有重复 ...

  3. Python第三天 序列 5种数据类型 数值 字符串 列表 元组 字典 各种数据类型的的xx重写xx表达式

    Python第三天 序列  5种数据类型  数值  字符串  列表  元组  字典 各种数据类型的的xx重写xx表达式 目录 Pycharm使用技巧(转载) Python第一天  安装  shell ...

  4. **python中列表 元组 字典 集合

    列表 元组 字典 集合的区别是python面试中最常见的一个问题.这个问题虽然很基础,但确实能反映出面试者的基础水平. 1.列表 列表是以方括号“[]”包围的数据集合,不同成员以“,”分隔. 列表的特 ...

  5. python的学习笔记01_4基础数据类型列表 元组 字典 集合 其他其他(for,enumerate,range)

    列表 定义:[]内以逗号分隔,按照索引,存放各种数据类型,每个位置代表一个元素 特性: 1.可存放多个值 2.可修改指定索引位置对应的值,可变 3.按照从左到右的顺序定义列表元素,下标从0开始顺序访问 ...

  6. Python入门基础学习(列表/元组/字典/集合)

    Python基础学习笔记(二) 列表list---[ ](打了激素的数组,可以放入混合类型) list1 = [1,2,'请多指教',0.5] 公共的功能: len(list1) #/获取元素 lis ...

  7. python 列表 元组 字典 集合

    列表 lst = [i for i in range(10)] 切片 # 把下标小于2的显示出来 print(lst[:2]) # 把10个数有大到小输出 print(lst[::-1]) # 把下标 ...

  8. Python 列表&元组&字典&集合

    列表(list) 有序性,可存储任意类型的值 通过偏移存取,支持索引来读取元素,第一个索引为0 ,倒数第一个索引为-1 可变性 ,支持切片.合并.删除等操作 可通过索引来向指定位置插入元素 可通过po ...

  9. Python列表,元组,字典,集合详细操作

    菜鸟学Python第五天 数据类型常用操作及内置方法 列表(list) ======================================基本使用====================== ...

  10. Python数据类型-布尔/数字/字符串/列表/元组/字典/集合

    代码 bol = True # 布尔 num = 100000000; # 数字 str = "fangbei"; # 字符串 str_cn = u"你好,方倍" ...

随机推荐

  1. python PIL 图片素描化

    from PIL import Image import numpy as np a = np.asarray(Image.open("D://7.jpg").convert('L ...

  2. 一、shell编程与变量

    目录 命令是什么 命令是如何运行的: 基本语法 解释器 注释 如何执行 输入.输出流 重定向 管道符 | 变量 常见Shell变量的类型包括: 变量命名原则 单引号和双引号 反引号 变量作用范围 查看 ...

  3. 从Vue源码中我学到了几点精妙方法

    话不多说,赶快试试这几个精妙方法吧!在工作中肯定会用得到. 立即执行函数 页面加载完成后只执行一次的设置函数. (function (a, b) { console.log(a, b); // 1,2 ...

  4. SprinigBoot自定义Starter

    自定义Starter 是什么 starter可以理解是一组封装好的依赖包,包含需要的组件和组件所需的依赖包,使得使用者不需要再关注组件的依赖问题 所以一个staerter包含 提供一个autoconf ...

  5. bat-Office激活命令

    激活命令 cd C:\Program Files\Microsoft Office\Office16 //然后目录对的话,该目录下面应该有个 OSPP.VBS cscript ospp.vbs /ds ...

  6. 实现一个Prometheus exporter

    Prometheus 官方和社区提供了非常多的exporter,涵盖数据库.中间件.OS.存储.硬件设备等,具体可查看exporters.exporterhub.io,通过这些 exporter 基本 ...

  7. rxjava回调地狱-kotlin协程来帮忙

    本文探讨的是在tomcat服务端接口编程中, 异步servlet场景下( 参考我另外一个文章),用rxjava来改造接口为全流程异步方式 好处不用说 tomcat的worker线程利用率大幅提高,接口 ...

  8. adb工具

    ADB:全称为Android Debug Bridge,它是 Android 开发/测试人员不可替代的强大工具.   首先,下载ADB工具并安装:   下载:百度就有.下载后是个压缩包,将其拷贝到cm ...

  9. CANN算子:利用迭代器高效实现Tensor数据切割分块处理

    摘要:本文以Diagonal算子为例,介绍并详细讲解如何利用迭代器对n维Tensor进行基于位置坐标的大批量数据读取工作. 本文分享自华为云社区<CANN算子:利用迭代器高效实现Tensor数据 ...

  10. 注册器机制Registry

    在众多深度学习开源库的代码中经常出现Registry代码块,例如OpenMMlab,facebookresearch和BasicSR中都使用了注册器机制.这块的代码经常会让新使用这些库的初学者感到一头 ...