Python学习-序列

列表

一、列表通用操作

in 和 not in
in用来检查指定元素是否存在于列表中
如果存在,返回True,否则返回False
not in用来检查指定元素是否不在列表中
如果不在,返回True,否则返回False

print('牛魔王' not in stus)
print('牛魔王' in stus)

**len()**获取列表中的元素的个数

min() 获取列表中的最小值
max() 获取列表中的最大值

arr = [10,1,2,5,100,77]
 print(min(arr) , max(arr))

两个方法(method),方法和函数基本上是一样,只不过方法必须通过 对象.方法() 的形式调用
xxx.print() 方法实际上就是和对象关系紧密的函数
s.index() 获取指定元素在列表中的第一次出现时索引

print(stus.index('沙和尚'))

index()的第二个参数,表示查找的起始位置 , 第三个参数,表示查找的结束位置

print(stus.index('沙和尚',3,7))

如果要获取列表中没有的元素,会抛出异常

print(stus.index('牛魔王')) ValueError: '牛魔王' is not in list

s.count() 统计指定元素在列表中出现的次数

print(stus.count('牛魔王'))

二、删除元素

创建一个列表

stus = ['孙悟空','猪八戒','沙和尚','唐僧','蜘蛛精','白骨精']

#修改列表中的元素
#直接通过索引来修改元素

stus[0] = 'sunwukong'
stus[2] = '哈哈'

通过del来删除元素

del stus[2] # 删除索引为2的元素

通过切片来修改列表
在给切片进行赋值时,只能使用序列

stus[0:2] = ['牛魔王','红孩儿'] 使用新的元素替换旧元素
stus[0:2] = ['牛魔王','红孩儿','二郎神']
stus[0:0] = ['牛魔王'] # 向索引为0的位置插入元素

当设置了步长时,序列中元素的个数必须和切片中元素的个数一致

stus[::2] = ['牛魔王','红孩儿','二郎神']

通过切片来删除元素

del stus[0:2]
del stus[::2]
stus[1:3] = []

以上操作,只适用于可变序列

s = 'hello'

s[1] = ‘a’ 不可变序列,无法通过索引来修改
可以通过 list() 函数将其他的序列转换为list

s = list(s)
print(s)

三、列表的方法

stus = ['孙悟空','猪八戒','沙和尚','唐僧']

append()
向列表的最后添加一个元素

stus.append('唐僧')

insert()
向列表的指定位置插入一个元素
参数:
1.要插入的位置
2.要插入的元素

stus.insert(2,'唐僧')

extend()
使用新的序列来扩展当前序列
需要一个序列作为参数,它会将该序列中的元素添加到当前列表中

stus.extend(['唐僧','白骨精'])
stus += ['唐僧','白骨精']

clear()
清空序列

stus.clear()

pop()
根据索引删除并返回被删除的元素

result = stus.pop(2) # 删除索引为2的元素
result = stus.pop() # 删除最后一个
print('result =',result)

remove()
删除指定值得元素,如果相同值得元素有多个,只会删除第一个

stus.remove('猪八戒')

reverse()
用来反转列表

stus.reverse()

sort()
用来对列表中的元素进行排序,默认是升序排列
如果需要降序排列,则需要传递一个reverse=True作为参数

my_list = [10,1,20,3,4,5,0,-2]
print('修改前',my_list)
my_list.sort(reverse=True)
print('修改后',my_list)

四、遍历列表

for s in stus :
    print(s)

元组 tuple

元组是一个不可变的序列
它的操作的方式基本上和列表是一致的
所以你在操作元组时,就把元组当成是一个不可变的列表就ok了
一般当我们希望数据不改变时,就使用元组,其余情况都使用列表

一、创建元组

使用()来创建元组

my_tuple = () # 创建了一个空元组
print(my_tuple,type(my_tuple)) # <class 'tuple'>

my_tuple = (1,2,3,4,5) # 创建了一个5个元素的元组

元组是不可变对象,不能尝试为元组中的元素重新赋值

my_tuple[3] = 10 TypeError: 'tuple' object does not support item assignment
print(my_tuple[3])

当元组不是空元组时,括号可以省略
如果元组不是空元组,它里边至少要有一个,

my_tuple = 10,20,30,40
print(my_tuple , type(my_tuple))

my_tuple = 10 , 20 , 30 , 40

二、元组的解包(解构)

解包指就是将元组当中每一个元素都赋值给一个变量

a,b,c,d = my_tuple

print("a =",a)
print("b =",b)
print("c =",c)
print("d =",d)

a = 100
b = 300
print(a , b)

交互a 和 b的值,这时我们就可以利用元组的解包

在对一个元组进行解包时,变量的数量必须和元组中的元素的数量一致
也可以在变量前边添加一个*,这样变量将会获取元组中所有剩余的元素

my_tuple = 10 , 20 , 30 , 40
a , b , *c = my_tuple
a , *b , c = my_tuple
*a , b , c = my_tuple
a , b , *c = [1,2,3,4,5,6,7]
a , b , *c = 'hello world'

不能同时出现两个或以上的*变量

*a , *b , c = my_tuple SyntaxError: two starred expressions in assignment
print('a =',a)
print('b =',b)
print('c =',c)

关于可变对象

a = [1,2,3]
print('修改前:', a , id(a))
# 修改前: [1, 2, 3] 2049163213696

#通过索引修改列表
a[0] = 10
print('修改后:', a , id(a))
#修改后: [10, 2, 3] 2049163213696

# 为变量重新赋值 
a = [4,5,6]
print('修改后:', a , id(a))
#修改后: [4, 5, 6] 2049175934016
a = [1,2,3]
b = a
print("a",a,id(a))
print("b",b,id(b))
#a [1, 2, 3] 2049164506880
#b [1, 2, 3] 2049164506880

b[0] = 10
print("a",a,id(a))
print("b",b,id(b))
#a [10, 2, 3] 2049164506880
#b [10, 2, 3] 2049164506880

b = [10,2,3]
print("a",a,id(a))
print("b",b,id(b))
#a [10, 2, 3] 2049164506880
#b [10, 2, 3] 2049166103744

== != is is not
== != 比较的是对象的值是否相等
is is not 比较的是对象的id是否相等(比较两个对象是否是同一个对象)

a = [1,2,3]
b = [1,2,3]
print(a,b)
print(id(a),id(b))
print(a == b) # a和b的值相等,使用==会返回True
print(a is b) # a和b不是同一个对象,内存地址不同,使用is会返回False

字典

一、字典的创建

使用 {} 来创建字典

d = {} # 创建了一个空字典

创建一个保护有数据的字典
语法:

{key:value,key:value,key:value}

字典的可以是任意对象
字典的可以是任意的不可变对象(int、str、bool、tuple …),但是一般我们都会使用str
字典的不能重复的,如果出现重复的后边的会替换到前边的

d = {'name':'孙悟空' , 'age':18 , 'gender':'男' , 'name':'sunwukong'}
d = {
'name':'孙悟空' , 
'age':18 , 
'gender':'男' , 
'name':'sunwukong'
}

使用 dict()函数来创建字典
每一个参数都是一个键值对,参数名就是键,参数名就是值(这种方式创建的字典,key都是字符串)

d = dict(name='孙悟空',age=18,gender='男') 

需要根据键来获取值

print(d['name'],d['age'],d['gender'])

如果使用了字典中不存在的键,会报错

print(d['hello']) KeyError: 'hello'

也可以将一个包含有双值子序列的序列转换为字典
双值序列,序列中只有两个值,[1,2] (‘a’,3) ‘ab’
子序列,如果序列中的元素也是序列,那么我们就称这个元素为子序列

[(1,2),(3,5)]
d = dict([('name','孙悟饭'),('age',18)])

len() 获取字典中键值对的个数

d = dict(name='孙悟空',age=18,gender='男') 
 print(len(d))

in 检查字典中是否包含指定的
not in 检查字典中是否不包含指定的

print('hello' in d)

获取字典中的值,根据键来获取值
语法:d[key]

print(d['age'])
 n = 'name'
print(d[n])

通过[]来获取值时,如果键不存在,会抛出异常 KeyError
get(key[, default]) 该方法用来根据键来获取字典中的值
如果获取的键在字典中不存在,会返回None
也可以指定一个默认值,来作为第二个参数,这样获取不到值时将会返回默认值

print(d.get('name'))
print(d.get('hello','默认值'))

二、修改字典

d[key] = value 如果key存在则覆盖,不存在则添加

d['name'] = 'sunwukong' # 修改字典的key-value
d['address'] = '花果山' # 向字典中添加key-value

setdefault(key[, default]) 可以用来向字典中添加key-value
如果key已经存在于字典中,则返回key的值,不会对字典做任何操作
如果key不存在,则向字典中添加这个key,并设置value

result = d.setdefault('name','猪八戒')
result = d.setdefault('hello','猪八戒')
print('result =',result)

update([other])
将其他的字典中的key-value添加到当前字典中
如果有重复的key,则后边的会替换到当前的

d = {'a':1,'b':2,'c':3}
d2 = {'d':4,'e':5,'f':6, 'a':7}
d.update(d2)

删除,可以使用 del 来删除字典中的 key-value

del d['a']
del d['b']

popitem()
随机删除字典中的一个键值对,一般都会删除最后一个键值对
删除之后,它会将删除的key-value作为返回值返回
返回的是一个元组,元组中有两个元素,第一个元素是删除的key,第二个是删除的value
当使用popitem()删除一个空字典时,会抛出异常 KeyError: ‘popitem(): dictionary is empty’

d.popitem()
result = d.popitem()

pop(key[, default])
根据key删除字典中的key-value
会将被删除的value返回!
如果删除不存在的key,会抛出异常
如果指定了默认值,再删除不存在的key时,不会报错,而是直接返回默认值

result = d.pop('d')
result = d.pop('z','这是默认值')

**clear()**用来清空字典

d.clear()

copy()
该方法用于对字典进行浅复制
复制以后的对象,和原对象是独立,修改一个不会影响另一个
注意,浅复制会简单复制对象内部的值,如果值也是一个可变对象,这个可变对象不会被复制

d = {'a':1,'b':2,'c':3}
d2 = d.copy()
d['a'] = 100
print('d = ',d , id(d)) #d =  {'a': 100, 'b': 2, 'c': 3} 2021326260888
print('d2 = ',d2 , id(d2)) #d2 =  {'a': 1, 'b': 2, 'c': 3} 2021326260968

三、遍历字典

keys() 该方法会返回字典的所有的key
该方法会返回一个序列,序列中保存有字典的所有的键
d = {‘name’:‘孙悟空’,‘age’:18,‘gender’:‘男’}

通过遍历keys()来获取所有的键

for k in d.keys() :
	print(k , d[k])

values()
该方法会返回一个序列,序列中保存有字典的左右的值

for v in d.values():
     print(v)

items()
该方法会返回字典中所有的项
它会返回一个序列,序列中包含有双值子序列
双值分别是,字典中的key和value

print(d.items())
for k,v in d.items() :
    print(k , '=' , v)

集合

一、集合创建

使用 {} 来创建集合 , {} 不能创建空集合

s = {10,3,5,1,2,1,2,3,1,1,1,1} # <class 'set'>
s = {[1,2,3],[4,6,7]} TypeError: unhashable type: 'list'

使用 set() 函数来创建集合

s = set() # 空集合

可以通过set()来将序列和字典转换为集合

s = set([1,2,3,4,5,1,1,2,3,4,5])
s = set('hello')
s = set({'a':1,'b':2,'c':3}) # 使用set()将字典转换为集合时,只会包含字典中的键

二、集合常用操作

使用in和not in来检查集合中的元素

s = {'a' , 'b' , 1 , 2 , 3 , 1}
print('c' in s)

使用**len()**来获取集合中元素的数量

print(len(s))

add() 向集合中添加元素

s.add(10)
s.add(30)

update() 将一个集合中的元素添加到当前集合中
update()可以传递序列或字典作为参数,字典只会使用键

s2 = set('hello')
s.update(s2)
s.update((10,20,30,40,50))
s.update({10:'ab',20:'bc',100:'cd',1000:'ef'})

**pop()**随机删除并返回一个集合中的元素

result = s.pop()

**remove()**删除集合中的指定元素

s.remove(100)
s.remove(1000)

**clear()**清空集合

s.clear()

三、集合运算

在对集合做运算时,不会影响原来的集合,而是返回一个运算结果
创建两个集合

s = {1,2,3,4,5}
s2 = {3,4,5,6,7}

& 交集运算

result = s & s2 # {3, 4, 5}

| 并集运算

result = s | s2 # {1,2,3,4,5,6,7}

- 差集

result = s - s2 # {1, 2}

^ 异或集 获取只在一个集合中出现的元素

result = s ^ s2 # {1, 2, 6, 7}

<= 检查一个集合是否是另一个集合的子集
如果a集合中的元素全部都在b集合中出现,那么a集合就是b集合的子集,b集合是a集合超集

a = {1,2,3}
b = {1,2,3,4,5}

result = a <= b # True
result = {1,2,3} <= {1,2,3} # True
result = {1,2,3,4,5} <= {1,2,3} # False

< 检查一个集合是否是另一个集合的真子集
如果超集b中含有子集a中所有元素,并且b中还有a中没有的元素,则b就是a的真超集,a是b的真子集

result = {1,2,3} < {1,2,3} # False
result = {1,2,3} < {1,2,3,4,5} # True

>= 检查一个集合是否是另一个的超集
> 检查一个集合是否是另一个的真超集

print('result =',result)

学习参考:
尚硅谷Python零基础入门教程全套完整版

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值