这两天准备面试和处理导师的项目(主要是自己贪玩),一直没时间学习,进度落后一大截,今天继续。
By the way,昨天已经收到了某大厂的实习offer(兴奋地躺了一整天),面试官表示对LINUX能力更看重一点,希望我入职前多多熟悉LINUX,所以我准备开个新坑(SQL的坑还没填上,我真哭了)。本来在想要不把Python往后放一放,但是又陆续收到了一些大厂的笔试邀请,一看全是编程,看来Python硬通货啊,为了我的秋招的幸福,接着学吧。
今日任务
列表、元组、字典、集合
列表
删除
list.pop([index=-1])
移除列表中的一个元素(默认最后一个元素),并且返回该元素的值
list.remove(obj)
移除列表中某个值的第一个匹配项
直接del
>>> list = ['Google', 'Runoob', 1997, 2000]
>>> print ("原始列表 : ", list)
原始列表 : ['Google', 'Runoob', 1997, 2000]
>>> del list[2]
>>> print ("删除第三个元素 : ", list)
删除第三个元素 : ['Google', 'Runoob', 2000]
比较
列表比较需要引入 operator 模块的 eq 方法
# 导入 operator 模块
import operator
a = [1, 2]
b = [2, 3]
c = [2, 3]
print("operator.eq(a,b): ", operator.eq(a,b))
print("operator.eq(c,b): ", operator.eq(c,b))
常见函数和方法
max(list)返回元素最大值,最小值同理
list.index(obj)
从列表中找出某个值第一个匹配项的索引位置
要想返回最大值的索引,可以用index函数,还有一些其他方法,比如enumerate,用的时候再查
lst = [1, 4, 8, 9,-1]
m = max(lst)
print(lst.index(m))
list.count(obj)
统计某个元素在列表中出现的次数
list.extend(seq)
在列表末尾一次性追加另一个序列中的多个值(用新列表扩展原来的列表),也可以用+符号操作
list.insert(index, obj)
将对象插入列表
list.reverse()
反向列表中元素
list.sort( key=None, reverse=False)
对原列表进行排序,默认是升序,如果要降序,reverse=True
list.clear()
清空列表
list.copy()
复制列表
元组
用()表示,与列表相似,可以截取、组合等,但是元素值是不可以修改的,也不能删除,但是可以使用del语句来删除整个元组
tup1=(1,2,3)
len(tup1),tup3=tup2+tup1,tup1+=tup2,tup3=tup*2,for i in tup1等用法都是可以的
max,min,tuple(list)
# 不支持修改元素
>>> tup = ('r', 'u', 'n', 'o', 'o', 'b')
>>> tup[0] = 'g' #报错
# 可以重新绑定新的地址
>>> tup = (1,2,3) #正确
字典
键必须是唯一的,且不可变。值不用
键可以是数字、字符串、元组,但是不能为列表(因为列表是可变的)
创建空字典可以直接用大括号,或者dict()函数
tinydict = {'Name': 'Runoob', 'Age': 7, 'Class': 'First'}
#添加新的键值对
tinydict['School'] = "菜鸟教程" # 添加信息
#删除键值对
del tinydict['Name']
#清空字典
tinydict.clear()
#删除字典
del tinydict
内置函数
len(dict)
计算字典元素个数,即键的总数。
str(dict)
输出字典,可以打印的字符串表示。
dict.copy()
返回一个字典的浅复制
dict.fromkeys()
创建一个新字典,以序列seq中元素做字典的键,val为字典所有键对应的初始值
>>> x=['a','b','c']
>>> z=dict.fromkeys(x,1)
>>> print(z)
{'a': 1, 'b': 1, 'c': 1}
dict.get(key, default=None)
返回指定键的值,如果键不在字典中返回 default 设置的默认值
dict.setdefault(key, default=None)
和get()类似, 但如果键不存在于字典中,将会添加键并将值设为default
dict.keys(),dict.values(),dict.items()
返回一个视图对象
>>> x={'name':'Alice','age':12}
>>> print(dict.items(x))
dict_items([('name', 'Alice'), ('age', 12)])
>>> print(dict.keys(x))
dict_keys(['name', 'age'])
>>> print(dict.values(x))
dict_values(['Alice', 12])
dict.pop(key[,default])
删除字典 key(键)所对应的值,返回被删除的值。
dict.popitem()
返回并删除字典中的最后一对键和值。
集合
无序的不重复元素序列
直接使用大括号或者set创建集合, 注意创建空集合只能使用set(),因为{}创建的是空字典
添加元素:
s.add()只能添加一个元素,s.update()可以添加多个元素
>>> thisset = set(("Google", "Runoob", "Taobao"))
>>> thisset.update({1,3})
>>> print(thisset)
{1, 3, 'Google', 'Taobao', 'Runoob'}
>>> thisset.update([1,4],[5,6])
>>> print(thisset)
{1, 3, 4, 5, 6, 'Google', 'Taobao', 'Runoob'}
移除元素:
s.remove(x),如果元素不存在,则会报错
s.discard(x),即使元素不存在,也不会报错
s.pop(),随即删除并返回删除的这个元素
常见函数:
s.clear()清空集合
s.copy()
issubset(),判断是否是子集
x= set(["Google", "Runoob", "Taobao"])
y= set(["Runoob"])
print(y.issubset(x))
还有一些集合的其他操作方法,比如并集、交集方法等,可直接用&、|,或者遇到了再查
终于把基本的变量类型过了一遍,感觉还是记不住。。。再复习复习吧