Python基础 Day2数据类型

列表

定义:[]内以逗号分隔,按照索引,存放各种数据类型,每个位置代表一个元素

再回顾下列表的特点:

1.可存放多个值

2.按照从左到右的顺序定义列表元素,下标从0开始顺序访问,有序

元素名ZifeiyuCoragemJackRachelMack
下标(索引)01234

3.可修改指定索引位置对应的值,可变

列表的增加操作

追加 数据会追加到尾部

>>> names
['zifeiyu', 'coragem']
>>> names.append("jack")
>>> names.append("rachel")
>>> 
>>> names
['zifieyu', 'coragem', 'jack', 'rachel']

插入 可插入任何位置

>>> names.insert(2,"黑姑娘")
>>> names
['zifieyu', 'coragem', '黑姑娘','jack', 'rachel']

合并 可以把另一外列表的值合并进来

>>> n2 = ["狗蛋","绿毛","鸡头"]
>>> names
['zifieyu', 'coragem', '黑姑娘','jack', 'rachel']
>>> names.extend(n2)
>>> names
['zifieyu', 'coragem', '黑姑娘','jack', 'rachel', '狗蛋', '绿毛', '鸡头']

列表嵌套

>>> names.insert(2,[1,2,3])
>>> names 
['zifieyu', 'coragem', [1, 2, 3], '黑姑娘','jack', 'rachel', '狗蛋', '绿毛', '鸡头']
>>> names[2][1]
2

删除操作

del 直接删

>>> names
['zifieyu', 'coragem', [1, 2, 3], '黑姑娘','jack', 'rachel', '狗蛋', '绿毛', '鸡头']
>>> del names[2]
>>> names
['zifieyu', 'coragem', '黑姑娘','jack', 'rachel', '狗蛋', '绿毛', '鸡头']

pop 删

>>> names
['zifieyu', 'coragem', '黑姑娘','jack', 'rachel', '狗蛋', '绿毛', '鸡头']
>>> names.pop() #默认删除最后一个元素并返回被删除的值
'鸡头'
>>> names
['zifieyu', 'coragem', '黑姑娘','jack', 'rachel', '狗蛋', '绿毛']
>>> names.pop(3)  #删除指定元素
'jack'

clear 清空

>>> n2
['狗蛋', '绿毛', '鸡头']
>>> n2.clear()
>>> n2
[]

修改操作

>>> names
['zifieyu', 'coragem', '黑姑娘', 'rachel', '狗蛋', '绿毛']
>>> names[0] = "部长"
>>> names[-1] = "副部"
>>> names
['部长', 'coragem', '黑姑娘', 'rachel', '狗蛋',  '副部']

查操作

>>> names
['部长', 'coragem', '黑姑娘', 'rachel', '狗蛋',  '副部',  'coragem']
>>> 
>>> names.index("coragem") #返回从左开始匹配到的第一个eva的索引
1
>>> names.count("coragem") #返回eva的个数
2

切片

切片就像切面包,可以同时取出元素的多个值

names[start:end] 
>>> names
['部长', 'coragem', '黑姑娘', 'rachel', '狗蛋',  '副部',  'coragem']
>>> names[1:4]  #不包含下标4的元素
[''coragem', '黑姑娘', 'rachel']

*切片的特性是顾头不顾尾,即start的元素会被包含,end-1是实际取出来的值
倒着切

>>> names[-5:-1]
['黑姑娘', 'rachel', '狗蛋',  '副部']

但其实我想要的是后5个,只打印了4个,’eva’这个值没出来,为什么,因为上面提到的顾头不顾尾

可是想把后5个全取出来如何做呢?

>>> names[-5:]
['黑姑娘', 'rachel', '狗蛋',  '副部',  'coragem']

如果取前几个值 ,一样可以把:号左边的省掉

>>> names
['部长', 'coragem', '黑姑娘', 'rachel', '狗蛋',  '副部',  'coragem']
>>> names[0:3]
['部长', 'coragem', '黑姑娘']
>>> names[:3]  #跟上面一样的效果
['部长', 'coragem', '黑姑娘']

步长 允许跳着取值

names[start:end:step] #step 默认是1
>>> a
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> a[0:7:2]  #设置步长为2
[0, 2, 4, 6]
>>> a
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> a[::3] #按步长3打印列表,第1个:是省略掉的start:end
[0, 3, 6, 9]

列表反转

>>> a[::-1] #通过把步长设置成负值,可达到列表返转的效果
[9, 8, 7, 6, 5, 4, 3, 2, 1, 0] 
>>> a[::-2]
[9, 7, 5, 3, 1]

元组

有些时候我们的列表数据不想被人修改时怎么办? 就可以用元组存放,元组又被称为只读列表,不能修改。

定义:与列表类似,只不过[]改成()

特性
  1.可存放多个值
  
  2.不可变
  
  3.按照从左到右的顺序定义元组元素,下标从0开始顺序访问,有序

创建

ages = (11, 22, 33, 44, 55)
#或
ages = tuple((11, 22, 33, 44, 55))

常用操作

索引

>>> ages = (11, 22, 33, 44, 55)
>>> ages[0]
11
>>> ages[3]
44
>>> ages[-1]
55

#切片:同list
循环

>>> for age in ages:
    print(age)
11
22
33
44
55

长度

>>> len(ages)
5

包含

>>> 11 in ages
True
>>> 66 in ages
False
>>> 11 not in ages
False

注意:元组本身不可变,如果元组中还包含其他可变元素,这些可变元素可以改变

>>> data 
(99, 88, 77, ['zifieyu', 'coragem'], 33)
>>> data[3][0] = 'Alex'
>>> data
(99, 88, 77, ['Alex',  'coragem'], 33)

字符串

定义

字符串是一个有序的字符的集合,用于存储和表示基本的文本信息,’ ‘或’’ ‘’或’’’ ‘’’中间包含的内容称之为字符串

创建

 s = 'Hello,Eva!How are you?'

特性

1.按照从左到右的顺序定义字符集合,下标从0开始顺序访问,有序
2.

strhello
索引01234

3.可以进行切片操作

4.不可变,字符串是不可变的,不能像列表一样修改其中某个元素,所有对字符串的修改操作其实都是相当于生成了一份新数据。

补充:

字符串的单引号和双引号都无法取消特殊字符的含义,如果想让引号内所有字符均取消特殊意义,在引号前面加r,如name=r’l\thf’

字典

引子
我们学了列表 , 现在有个需求, 把你们公司每个员工的姓名、年龄、职务、工资存到列表里,你怎么存?

staff_list = [
    ["Xifeiyu",20,"CEO",66000],
    ["Coragem",19,"讲师",40000],
    ["Jack","行政",4000],
    # [xxx,xx,xx,xxx]
    # [xxx,xx,xx,xxx]
    # [xxx,xx,xx,xxx]  
]

这样存没问题,不过你要查一个人的工资的话, 是不是得把列表遍历一遍

for i in staff_list:
    if i[0] == 'Coragem':
        print(i)
        break

但假如你公司有2万人,如果你要找的黑姑娘正好在列表末尾,那意味着你要遍历2万次,才能找到这个信息。列表越大,查找速度越慢。

好了,现在福音来了, 接下来学要的字典可以 查询数据又快、操作又方便,简直堪称神器。

定义

{key1:value1,key2:value2}

1、键与值用冒号“:”分开;
2、项与项用逗号“,”分开;

示例:

info = {
    "name":"小猿圈",
    "mission": "帮一千万极客高效学编程",
    "website": "http://apeland.com"
}

特性

1.key-value结构

2.key必须为不可变数据类型、必须唯一

3.可存放任意多个value、可修改、可以不唯一

4.无序

5.询速度快,且不受dict的大小影响,至于为何快?我们学完hash再解释。

操作

创建操作

>>>person = {"name": "alex", 'age': 20} 
#或
>>>person = dict(name='seven', age=20)
#或
>>>person = dict({"name": "egon", 'age': 20})
#或
>>> {}.fromkeys([1,2,3,4,5,6,7,8],100)
{1: 100, 2: 100, 3: 100, 4: 100, 5: 100, 6: 100, 7: 100, 8: 100} 

增加操作

names = {
    "alex": [23, "CEO", 66000],
    "黑姑娘": [24, "行政", 4000],
}

#新增k
names["佩奇"] = [26, "讲师", 40000]
names.setdefault("oldboy",[50,"boss",100000])  # D.setdefault(k[,d]) -> D.get(k,d), also set D[k]=d if k not in D

删除操作

names.pop("alex") # 删除指定key
names.popitem()   # 随便删除1个key
del names["oldboy"] # 删除指定key,同pop方法
names.clear()     # 清空dict

修改操作

dic['key'] = 'new_value',如果key在字典中存在,'new_value'将会替代原来的value值;
dic.update(dic2) 将字典dic2的键值对添加到字典dic中

查操作

dic['key'] #返回字典中key对应的值,若key不存在字典中,则报错;
dic.get(key, default = None)#返回字典中key对应的值,若key不存在字典中,则返回default的值(default默认为None)
'key' in dic #若存在则返回True,没有则返回False
dic.keys() 返回一个包含字典所有KEY的列表;
dic.values() 返回一个包含字典所有value的列表;
dic.items() 返回一个包含所有(键,值)元组的列表;

循环

for k in dic.keys()
for k,v in dic.items() 
for k in dic   # 推荐用这种,效率速度最快
info = {
    "name":"废材",
    "mission": "学不会编程",
    "website": "http://apeland.com"
}
for k in info:
    print(k,info[k])
输出
name 废材
mission	学不会编程
website http://apeland.com

求长度

len(dic)

集合

特点

  1. 里面的元素不可变,代表你不能存一个list、dict 在集合里,字符串、数字、元组等不可变类型可以存
  2. 天生去重,在集合里没办法存重复的元素
  3. 无序,不像列表一样通过索引来标记在列表中的位置 ,元素是无序的,集合中的元素没有先后之分,如集合{3,4,5}和{3,5,4}算作同一个集合
  4. 基于上面的特性,我们可以用集合来干2件事,去重和关系运算

语法

创建语法

>>> a = {1,2,3,4,2,'alex',3,'rain','alex'}
>>> a
{1, 2, 3, 4, 'alex', 'rain'}

由于它是天生去重的,重复的值你根本存不进去

帮列表去重

帮列表去重最快速的办法是什么? 就是把它转成集合,去重完,再转回列表

>>> b
[1, 2, 3, 4, 2, 'alex', 3, 'rain', 'alex']
>>> set(b)
{1, 2, 3, 4, 'alex', 'rain'}
>>> 
>>> b = list(set(b)) #一句代码搞定
>>> b
[1, 2, 3, 4, 'alex', 'rain']

增删改查

>>> a
{1, 2, 3, 4, 'alex', 'rain'}
#新增
>>> a.add('黑姑娘')  
#删除discard
>>> a
{2, 3, '黑姑娘', 'alex', 'rain'}
>>> a.discard('rain')   #删除一个存在的值
>>> a.discard('rain2')   #如果这个值不存在,do nothing.
>>> a
{2, 3, '黑姑娘', 'alex'}
>>> 
#随机删除,少用,或特定场景用
>>> a.pop() #删除并返回
1
#删除remove
>>> a.remove(4)
#查
>>> a
{2, 3, '黑姑娘', 'alex', 'rain'}
>>> 'alex' in a
True
#改
呵呵,不能改。。。 

关系运算

s_1024 = {"佩奇","老男孩","海峰","马JJ","老村长","黑姑娘","Alex"}
s_pornhub = {"Alex","Egon","Rain","马JJ","Nick","Jack"}
print(s_1024 & s_pornhub)  # 交集, elements in both set
print(s_1024 | s_pornhub)  # 并集 or 合集
print(s_1024 - s_pornhub)  # 差集 , only in 1024
print(s_pornhub - s_1024)  # 差集,  only in pornhub
print(s_1024 ^ s_pornhub)  # 对称差集, 把脚踩2只船的人T出去

两个集合之间一般有三种关系,相交、包含、不相交。在Python中分别用下面的方法判断:

print(s_1024.isdisjoint(s_pornhub))     # 判断2个集合是不是不相交,返回True or False
print(s_1024.issubset(s_pornhub))       # 判断s_1024是不是s_pornhub的子集,返回True or False
print(s_1024.issuperset(s_pornhub))     # 判断s_1024是不是s_pornhub的父集,返回True or False
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值