Python中分为六种基本数据类型

  • 不可变类型(又叫静态数据类型,没有增删改操作):数字(number)、字符串(string)、元组(tuple)
  • 可变类型(又叫动态数据类型,支持增删改操作):列表(list)、字典(dictionary)、集合(set)

1. 数字类型(numbers):

数字类型下还可分为整数(int)、浮点数(float)、复数(complex)、布尔(bool)

age = 22# 整数型,可以通过print(sys.maxsize)查看最大取值范围print(age)# 输出:22weight = 116.65 # 浮点型print(weight) # 输出:116.65c1 = 1 + 2jc2 = 2 + 3jprint(c1+c2)# 输出:(3+5j),复数在实际工作中几乎用不到,请自行了解print(complex(2,1)) # 输出:(2+1j)print(True == 1)# 输出:Trueprint(False == 0) # 输出:True# True==1,False==0 ,因此True 和 False 可以和数字相加print(True + 1) # 输出:2print(False - 2)# 输出:-2# ↓其实布尔型就是整数型的子类,可以使用内置函数issubclass()判断,该函数是用于判断一个类型对象是否是另一个类型对象的子类print(issubclass(bool, int)) # 输出:True

2. 字符串类型(string)

字符串必须使用''""括起来,对于特殊字符可以使用反斜杠\进行转义,用+拼接多个字符串, 用*复制字符串,字符串还支持索引截取(又叫切片)

name = "ZhangSan" # 字符串型,也可以使用单括号print(name) # 输出:ZhangSanprint(name * 2)# 输出字符串两次,也可以写成 print (2 * name),输出:ZhangSanZhangSanprint(name +'-123')# 拼接字符串,输出:ZhangSan-123print(name +'\'123\'')# 拼接字符串并将单引号转义,输出:ZhangSan'123'print(name[0:-1])# 输出第一个至倒数第二个的字符,截取时顾头不顾尾,输出:ZhangSaprint(name[0]) # 输出第一个字符,输出:Zprint(name[-1])# 输出最后一个字符,输出:nprint(name[2:])# 输出从第三个开始之后的所有字符,输出:angSanprint(name[0:-1:2]) # 输出第一个至倒数第二个的字符,步长为2,输出:Zagaprint(name[8])# 若字符不存在,则会抛出IndexError: string index out of range

3. 列表(list)

列表是一组可重复且有序的数据集合,任何类型的数据都可以存到列表中,会根据需要动态分配和回收内存,是Python中使用最频繁的数据类型,列表同样也支持索引截取(又叫切片),列表中的元素是可变的,能够进行增删改操作

  • 列表创建

    l0 = []# 创建空列表l1 = ["张三",'lisi',12,["22","lisi","王武"],"赵柳"]# 直接使用中括号创建列表l2 = list(['lisi',12,("22","王武"),"赵柳"])# 或者调用内置函数list(),通常用于转换为列表时使用
  • 获取列表中的元素

    print(l1[1])# 获取列表l1中第二个元素,输出:lisiprint(l1[0:2])# 获取列表l1中第一个和第二个元素,输出:['张三', 'lisi']print(l1[-5:-2])# 获取列表l1中第一个至倒数第三个数据,反向索引,输出:['张三', 'lisi', 12]print(l1[2:-1]) # 获取列表l1中第三个至倒数第二个元素,输出:[12, ['22', 'lisi', '王武']]print(l1[1::2]) # 获取列表l1中第二个至最后一个元素,步长为2,输出:['lisi', ['22', 'lisi', '王武']]print(l1[:1:-2])# 反向获取列表l1中元素,步长为-2,输出:['赵柳', 12]print(l1[::-1]) # 步长为-1时表示倒序排列元素,输出:['赵柳', ['22', 'lisi', '王武'], 12, 'lisi', '张三']print(l1[3][0]) # 获取l1嵌套列表(即第四个元素)中的第一个元素,输出:22print(l1[3][-1])# 获取l1嵌套列表(即第四个元素)中的最后一个元素,输出:王武print(l1[5])# 若元素不存在,则会抛出IndexError: list index out of rangefor i in l1:# 使用for循环遍历列表中的元素print(i)# 遍历元素后的操作,比如输出结果
  • 判断元素是否在列表中

    print("lisi" in l1) # 判断l1列表中包含“lisi”,输出:Trueprint("赵柳" not in l1)# 判断l1列表中不包含“赵柳”,输出:Falseprint("22" in l1[3])# 判断l1嵌套列表中包含“22”,输出:Trueprint("王武" not in l1)# 判断l1列表中不包含“王武”,输出:True
  • 列表排序

    li = [22,18,9,-2,0,6]# 对于需要排序的列表,元素类型必须一致,比如:元素统一为数字类型或字符串类型li.sort()# 调用sort()方法,默认从小到大排序li.sort(reverse=True)# 指定reverse=True后列表会进行降序排列# ↓还可以调用内置函数sorted()进行排序,此方式不会改变原列表sorted(li)# 从小到大排序sorted(li,reverse=True)# 同样指定reverse=True后列表会进行降序排列
  • 修改列表中的元素

    l1[1]="李思" # 将l1列表中第二个元素改为李思l1[3][0] = 22# l1嵌套列表中的第一个元素改为22l1[1:3]= ["张珊","李思"]# 将l1列表中第二个和第三个值改为张珊和李思
  • 列表中添加元素

    l3 = [1,2]l4 = ["壹","er"]l3.append(3)# 在l3列表末尾添加元素3,输出:[1, 2, 3]l3.append(l4)# 将l4列表添加到l3列表末尾,输出:[1, 2, ['壹', 'er']]l3.extend("3L")# 在l3列表末尾至少添加两个元素,输出:[1, 2, '3', 'L']l3.extend(l4)# 将l4列表添加到l3列表末尾,等同于l3+l4,输出:[1, 2, '壹', 'er']l3.insert(1,"张珊")# 在l3列表中索引为1的位置插入元素,输出:[1, '张珊', 2]l3.insert(0,l4)# 将l4列表添加到l3列表头部,输出:[['壹', 'er'], 1, 2]

    注意三者的区别:

    • append():指在列表的末尾添加一个元素,新元素会视为一个整体追加到列表末尾
    • extend():指在列表的末尾至少添加一个元素,新元素会将整体中的每个元素一个一个地追加列表末尾
    • insert():指在列表的指定索引位置添加元素
  • 删除列表中的元素

    l1.remove("张珊")# 删除指定元素,一次只能删除一个元素,若出现重复元素则只删除第一个l1.remove("菡菡")# 若元素不存在,则抛出ValueError: list.remove(x): x not in listl1.pop(1)# 删除指定索引位置上的元素,若不指定索引则默认删除最后一个元素l1.pop(8)# 若索引不存在,则抛出IndexError: pop index out of rangel1.clear()# 清空l1列表del l1# 删除l1列表

4. 元组(tuple)

元组也是一组可重复且有序的对象集合,任何类型的数据都可以存到元组中,但是元组中的元素是不可变的,元组同样也支持索引截取(又叫切片)

  • 创建元组

    t0 = ()# 创建空元组t1 = ("张珊","lisi",["李思",12,"Python"],("王武","22"))# 直接使用小括号创建元组t2 = (1,)# 当元组只有一个元素时需要在后面加上逗号t3 = tuple(("依儿",22,"Java")) # 或者调用内置函数tuple(),通常用于转换为元组时使用
  • 获取元组中的元素

    print(t1[1])# 获取元组t1中第二个元素,输出:lisiprint(t1[0:2])# 获取元组t1中第一个和第二个元素,输出:('张珊', 'lisi')print(t1[2:-1]) # 获取元组t1中第三个至倒数第二个元素,输出:(['李思', 12, 'Python'],)print(t1[1::2]) # 获取元组t1中第二个至最后一个元素,步长为2,输出:('lisi', ('王武', '22'))print(t1[::-1]) # 步长为-1时表示倒序排列,输出:(('王武', '22'), ['李思', 12, 'Python'], 'lisi', '张珊')print(t1[2][0:-1]) # 获取元组t1中第三个元素中的第一个至倒数第二个元素,输出:['李思', 12]for i in t1:# 使用for循环遍历元组中的元素print(i)# 遍历元素后的操作,比如输出结果
  • 修改元组中的可变对象

    # 修改元组t1中列表中的元素t1[2][1] = "十" # 将12改为10t1[2].remove("Python")# 删除Python元素t1[2].pop()# 删除最后一个元素t1[2].clear()# 清空列表t1[2].append("啊哈") # 添加一个元素# 拼接元组print(t2+t3)# 输出:('1', '依儿', 22, 'Java')

    注意:元组中存储的是对象的引用,若对象本身不可变则不可再引用其它对象(比如元组t2和t3,元素都是不可修改的),若对象本身可变则可变对象的引用不可改变,但是对象中的数据可以改变(比如t1中的列表,该列表不可删除,但可以修改列表中的元素)

5. 字典(dictionary)

字典是一组可变的无序的对象集合,字典中的元素是通过键(Key) : 值(Value)来保存的,一组键值对称为一个元素,其中键(Key)不可重复,必须唯一,而值(Value)是可重复的,字典会浪费较大内存,是一种使用空间换时间的数据类型

  • 创建字典

    d0 = {}# 创建空字典d1 = {"张珊":100,"李思":120,"王武":110}# 使用花括号创建字典d2 = dict(name="李尔",weight=116) # 调用内置函数dict()创建,通常用于转换为字典时使用
  • 获取字典中的元素

    print(d1["李思"])# 使用中括号根据Key获取Value值,输出:120print(d1["张三"])# 若Key不存在,则抛出KeyError: '张三'# ↓还可以使用get()方法取值,此方式若Key不存在则返回None,不会抛出KeyError异常,还可以设置默认Valueprint(d1.get("张珊"))# 使用get()方法取值,输出:100print(d1.get("王武",98))# 若对应Key不存在则输出默认值,否则输出对应的Value值,此处输出:110# ↓使用keys()方法获取所有Keyprint(d1.keys()) # 获取字典中所有的Key,输出:dict_keys(['张珊', '李思', '王武'])print(list(d1.keys())) # 获取字典中所有的Key并转为列表,输出:['张珊', '李思', '王武']print(tuple(d1.keys())) # 获取字典中所有的Key并转为元组,输出:('张珊', '李思', '王武')# ↓使用values()方法获取所有Value值print(d1.values()) # 获取字典中所有的Value值,输出:dict_values([100, 120, 110])print(list(d1.values())) # 获取字典中所有的Value值并转为列表,输出:[100, 120, 110]print(tuple(d1.values()))# 获取字典中所有的Value值并转为元组,输出:(100, 120, 110)# ↓使用items()方法获取所有的键值对print(d1.items()) # 获取字典中所有的Key:Value,输出:dict_items([('张珊', 100), ('李思', 120), ('王武', 110)])print(list(d1.items())) # 获取字典中所有的Key:Value并转为列表,输出:[('张珊', 100), ('李思', 120), ('王武', 110)]print(tuple(d1.items())) # 获取字典中所有的Key:Value并转为元组,输出:(('张珊', 100), ('李思', 120), ('王武', 110))for item in d1: # 使用for循环遍历字典中的元素print(item) # 返回字典中所有的Key
  • 判断字典中是否存在指定的Key

    print("李思" in d1)# 判断d1字典中存在Key"李思",输出:Trueprint("王武" not in d1)# 判断d1字典中不存在Key"王武",输出:False
  • 字典中元素的增删改

    d1["李思"] = 118# 若Key存在,则修改对应的Value值,原李思对应的value值变为118d1["张三"] = 106# 若Key不存在,则新增键值对,字典中新增'张三': 106d1.pop("张三")# 删除Key为“张三”的键值对d1.pop("张凤")# 必须传入一个Key,若Key不存在,则抛出KeyError: '张凤'del d1["张三"]# 同样也是删除Key为“张三”的键值对d1.clear() # 清空字典del d1 # 删除字典

6. 集合(set)

集合是一组可变的、无序的且不可重复的元素序列,可以理解为是没有Value值得字典,基本功能是测试元素之间的关系和删除重复元素,比如:共同好友、你可能认识的人、关注TA的人还关注了…等

  • 创建集合

    s0 = set() # 创建空集合,不能直接使用花括号,花括号默认是创建字典s1 = {"李思","张珊","李思","王武"}# 花括号中元素非键值对时,创建的是集合s2 = set("李尔")# 调用内部函数set()创建,通常用于转换为集合时使用
  • 获取集合中的元素

    # ↓若集合中存在相同的元素,只会出现输出一个,因为集合是无序的,所以每次输出结果顺序可能不一致print(s1)# 获取集合s1中所有的元素,输出:{'李思', '王武', '张珊'} for i in s1:# 通过for循环获取集合中的元素print(i)# 同样重复元素只返回一个# ↓集合中的某一个元素是不能直接获取的,可以先转换为列表,然后使用列表方式获取元素ls = list(s1)# 将集合s1转换为列表print(ls[1])# 获取列表l1中第二个元素,输出:李思print(ls[0:2])# 获取列表l1中第一个和第二个元素,输出:['王武', '李思']……
  • 判断元素是否存在

    print("李思" in s1)# 判断s1集合中存在"李思",输出:Trueprint("王武" not in s1)# 判断s1集合中不存在"王武",输出:False
  • 集合中添加、更新元素

    s1.add("赵柳")# 添加一个元素,因为集合是无序的,所以元素位置随机# update也可以理解为新增,当存在相同元素时,相同元素会被覆盖,不同元素会新增到集合中s1.update("张三")# 集合中会添加两个元素,‘张’、‘三’s1.update("张三丰") # 集合中会更新两个元素,‘张’和‘三’,新增一个元素‘丰’
  • 删除集合中的元素

    s1.remove("李思")# 删除s1集合中的元素“李思”,若元素不存在,则抛出KeyError: '李思's1.discard("张三")# 删除s1集合中的元素“张三”,若元素不存在,不会抛出任何异常s1.pop()# 随机删除任意一个元素s1.clear()# 清空集合中的元素del s1# 删除集合
  • 判断两个集合是否相等

    print(s1 == s2)# 输出:Falseprint(s1 != s2)# 输出:True
  • 判断两个集合的关系

    s3 = {"李思","张珊","李思","王武","Andy"}s4 = {"李四","张珊","张三","王武"}s5 = {"Andy"}# ↓当s5中所有的元素s3里都有,但s5中的元素s3中未必有,则s3就是s5的超级,反之s5就是s3子集print(s3.issuperset(s5))# 判断s3是否是s5的超集,输出:True,因为s3中有s5所有的元素print(s5.issubset(s3))# 判断s5是否是s3的子集,输出:True,因为s5中的所有元素s3中都有print(s3.isdisjoint(s4))# 判断s3和s4两个集合是否没有交集,输出:False,因为两个集合中都有"张珊"和"王武",存在交集print(s3.intersection(s4))# 输出s3和s4交集(即二者都有)的元素,输出:{'张珊', '王武'}print(s3 & s4)# 与intersection()等价,交集的一种符号表示法print(s3.union(s4))# 输出s3和s4并集(即去掉二者都有)的元素,输出:{'李思', '张三', '王武', '李四', '张珊', 'Andy'}print(s3 | s4)# 与union()等价,并集的一种符号表示法print(s3.difference(s4))# 输出s3和s4差集(即所有属于s3但不属于s4)的元素,输出:{'Andy', '李思'}print(s3 - s4)# 与union()等价,差集的一种符号表示法print(s3.symmetric_difference(s4))# 输出s3和s4对称差集(即s3中不属于s4和s4中不属于s3)的元素,输出:{'Andy', '李思', '李四', '张三'}print(s3 ^ s4)# 与symmetric_difference()等价,对称差集的一种符号表示法