list(列表)
- list的创建
- 直接创建,用中括号,其中内容用英文逗号隔开
- L1 = [1,2,3,a,b,c]
- 第二种方法
- L2 = list()
列表的常见操作
- 访问
- 使用下标操作,也叫索引
- 元素索引从零开始
- 切片
- 对列表进行任意一段的截取
- 截取后生成新的列表
# del 删除
a = [1,2,3,4,5,6]
del a[2]
print(a)
[1, 2, 4, 5, 6]
# 使用加号链接两个列表
a = [1,2,3,4,5]
b = [5,6,7,8,9]
d = ['a', 'b', 'c']
c = a + b + d
print(c)
[1, 2, 3, 4, 5, 5, 6, 7, 8, 9, 'a', 'b', 'c']
# 使用乘号操作列表
# 列表直接跟一个整数相乘
# 相当于把n个列表接在一起
a = [1,2,3,4,5]
b = a *3
print(b)
[1, 2, 3, 4, 5, 1, 2, 3, 4, 5, 1, 2, 3, 4, 5]
# 成员资格运算
# 就是判断一个元素是否在list里边
a = [1,2,3,4,5,6]
b = 8
#c 的值是一个布尔值
c = b in a
print(c)
b = 4
print(b in a)
# not in
a = [1,2,3,4,5]
b = 9
print(b not in a)
False
True
True
#访问
L1 = [1,2,3,'a','b','c']
print(L1[0])
#切片
print(L1[1:4])
#切片后生成的是一个全新的list
print(id(L1))
print(id(L1[1:4]))
1
[2, 3, 'a']
3201539332552
3201539332744
#切片下标可以为空
print(L1[:4])
print(L1[2:])
#切片可自己控制步长
print(L1[::2])
#下标为负数,表明顺序是从右往左
# 规定:数组最后一个数字的下标是-1
#步长为负表示从右到左
print(L1[-1:-6:-1])
[1, 2, 3, 'a']
[3, 'a', 'b', 'c']
[1, 3, 'b']
['c', 'b', 'a', 3, 2]
# append 插入一个内容, 在末尾追加
a = [ i for i in range(1,5)]
print(a)
a.append(100)
print(a)
[1, 2, 3, 4]
[1, 2, 3, 4, 100]
# insert: 制定位置插入
# insert(index, data), 插入位置是index前面
print(a)
a.insert(3, 666)
print(a)
[1, 2, 3, 4, 100]
[1, 2, 3, 666, 4, 100]
print(a)
last_ele = a.pop()
print(last_ele)
print(a)
[1, 2, 3, 666, 4, 100]
100
[1, 2, 3, 666, 4]
# reverse:翻转列表内容,原地翻转
a = [ 1,2,3,4,5]
print(a)
print(id(a))
a.reverse()
print(a)
print(id(a))
[1, 2, 3, 4, 5]
2596034940424
[5, 4, 3, 2, 1]
2596034940424
# extend:扩展列表,两个列表,把一个直接拼接到后一个上
a = [ 1,2,3,4,5]
b = [6,7,8,9,10]
print(a)
print(id(a))
a.extend(b)
print(a)
print(id(a))
[1, 2, 3, 4, 5]
2596033784456
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
2596033784456
# copy: 拷贝,此函数是浅拷贝,
# 列表类型变量赋值示例
a = [1,2,3,4,5,666]
print(a)
# list类型,简单赋值操作,是传地址
b = a
b[3] = 777
print(a)
print(id(a))
print(b)
print(id(b))
print("-" * 20)
# 为了解决以上问题,list赋值需要采用copy函数
b = a.copy()
print(a)
print(id(a))
print(b)
print(id(b))
print("-" * 20)
b[3] = 888
print(a)
print(b)
[1, 2, 3, 4, 5, 666]
[1, 2, 3, 777, 5, 666]
2596034940232
[1, 2, 3, 777, 5, 666]
2596034940232
--------------------
[1, 2, 3, 777, 5, 666]
2596034940232
[1, 2, 3, 777, 5, 666]
2596034940168
--------------------
[1, 2, 3, 777, 5, 666]
[1, 2, 3, 888, 5, 666]
# 深拷贝跟浅拷贝的区别
# 出现下列问题的原因是,copy‘函数是个浅拷贝函数,即只拷贝一层内容
# 深拷贝需要使用特定工具
a = [1,2,3, [10, 20, 30]]
b = a.copy()
print(id(a))
print(id(b))
print(id(a[3]))
print(id(b[3]))
a[3][2] = 666
print(a)
print(b)
2596034938952
2596034937608
2596034938632
2596034938632
[1, 2, 3, [10, 20, 666]]
[1, 2, 3, [10, 20, 666]]
# capitalize 首字母大写,其余小写,返回字符串
s = 'i Love xiaoliu'
print(s.capitalize())
# title 每个首字母大写
print(s.title())
#upper 所有字母大写
print(s.upper())
#lower 所有字母小写
print(s.lower())
#swapcase 大小写互换
print(s.swapcase())
I love xiaoliu
I Love Xiaoliu
I LOVE XIAOLIU
i love xiaoliu
I lOVE XIAOLIU
列表内置函数
https://www.runoob.com/python3/python3-list.html
tuple(元组)
- 可理解为一个不允许修改的列表
- 总之,list所有特性,除了可修改外,元组都具有
- list具有的一些操作,比如索引,分片,序列相加,相乘,成员资格操作等,一模一样
- tuple其余特征和list基本一致
- 有序
- 可以访问不可以被修改
- 元素可以是任意类型
元组内置函数
https://www.runoob.com/python3/python3-tuple.html
# tuple创建
# 1.直接用小括号
ta = ()
print(type(ta))
# 2.直接用逗号
tb = 100,
print(type(tb))
#3.用关键字tuple
tc = tuple()#要求tuple的参数必须可迭代
print(type(tc))
<class 'tuple'>
<class 'tuple'>
<class 'tuple'>
# 常用元组函数
ta = (1,2,3,4,5,6,7,8,9)
# len:长度
print(len(ta))
# max/min 不同类型不能比较
print(max(ta),min(ta))
# count:对某一元素计数
tb = (1,1,1,1,2,2,2,3,3,3)
print(tb.count(1))
# index:某一元素所在位置
print(ta.index(6))
9
9 1
4
5
set(集合)
- 和数学中概念一致
- 无序 + 内容不重复
集合内置函数
https://www.runoob.com/python3/python3-set.html
# 创建集合
# 1. set关键字
li = [1,1,2,3,3,5,5,2,63,6,2,2,4,3]
sa = set(li)
print(sa)
{1, 2, 3, 4, 5, 6, 63}
# 2.使用大括号
sb = {1,2,3,1,2,3,1,2,3}
print(sb)
{1, 2, 3}
# 集合生成式
sa = {1,2,3,4,5,6,7,8,9}
sb = {i for i in sa}
print(sb)
sc = {i for i in sa if i % 2 == 0}
print(sc)
{1, 2, 3, 4, 5, 6, 7, 8, 9}
{8, 2, 4, 6}
# 集合常用函数
# len max/ min
# add:向集合中添加元素
sa = {1,2,3,4,5,6}
print(sa.add(7))
print(sa)
# clear:清空
print(sa.clear())
None
{1, 2, 3, 4, 5, 6, 7}
None
# 删除操作
# remove 和 discard 的区别
sa = {1,2,3,4,5,6,7,8,9}
# remove 删除不存在的元素报错
print(sa.remove(10))
---------------------------------------------------------------------------
KeyError Traceback (most recent call last)
<ipython-input-10-012c1827640f> in <module>
3 sa = {1,2,3,4,5,6,7,8,9}
4 # remove 删除不存在的元素报错
----> 5 print(sa.remove(10))
KeyError: 10
# remove 和 discard 的区别
sa = {1,2,3,4,5,6,7,8,9}
# discard 删除不存在的元素不会报错
sa.discard(10)
print(sa)
{1, 2, 3, 4, 5, 6, 7, 8, 9}
# pop弹出集合一个内容
# 删除的内容是随机的
sa = {1,2,3,4,5,6,7,8,9}
sa.pop()
print(sa)
{2, 3, 4, 5, 6, 7, 8, 9}
# 集合的数学操作
sa ={1,2,3,4,5,6}
sb = {4,5,6,7,8,9}
# intersection:交集
print(sa.intersection(sb))
# difference:差集
print(sa.difference(sb))
print(sb.difference(sa))
#差集也可用 - 表示
print(sa - sb)
#union:并集 并集不能用+号表示
print(sa.union(sb))
{4, 5, 6}
{1, 2, 3}
{8, 9, 7}
{1, 2, 3}
{1, 2, 3, 4, 5, 6, 7, 8, 9}
frozenset(冰冻集合)
- 不允许修改的集合
#案例
print(sa)
sb = frozenset(sa)
print(sb)
{1, 2, 3, 4, 5, 6}
frozenset({1, 2, 3, 4, 5, 6})
dict(字典)
- 字典是一种组合数据,没有顺序的组合数据,数据以键值对形式出现
字典内置函数
https://www.runoob.com/python3/python3-dictionary.html
# 字典的创建
d = {}
print(type(d))
# 创建有值的字典, 每一组数据用冒号隔开, 每一对键值对用逗号隔开
d = {'one': 1,'tow': 2,'therr': 3}
print(d)
<class 'dict'>
{'one': 1, 'tow': 2, 'therr': 3}
字典的特征
- 字典是序列类型,但是是无序序列,所以没有分片和索引
- 字典中的数据每个都有键值对组成,即kv对
- key: 必须是可哈希的值,比如int,string,float,tuple, 但是,list,set,dict 不行
- value: 任何值
# 访问数据
d = {"one":1, "two":2, "three":3}
# 中括号内是键值
print(d["one"])
d["one"] = "eins"
print(d)
# 删除某个操作
# 使用del操作
del d["one"]
print(d)
1
{'one': 'eins', 'two': 2, 'three': 3}
{'two': 2, 'three': 3}
# 成员检测, in, not in
# 成员检测检测的是key内容
d = {"one":1, "two":2, "three":3}
if 2 in d:
print("value")
if "two" in d:
print("key")
if ("two",2) in d:
print("kv")
key
# 按key来使用for循环
d = {"one":1, "two":2, "three":3}
# 使用for循环,直接按key值访问
for k in d:
print(k, d[k])
# 上述代码可以改写成如下
for k in d.keys():
print(k, d[k])
# 只访问字典的值
for v in d.values():
print(v)
# 注意以下特殊用法
for k,v in d.items():
print(k,'--',v)
one 1
two 2
three 3
one 1
two 2
three 3
1
2
3
one -- 1
two -- 2
three -- 3
d = {"one":1, "two":2, "three":3}
# 常规字典生成式
dd = {k:v for k,v in d.items()}
print(dd)
# 加限制条件的字典生成式
dd = {k:v for k,v in d.items() if v % 2 == 0}
print(dd)
{'one': 1, 'two': 2, 'three': 3}
{'two': 2}
# keys:返回字典的键组成的一个结构
k = d.keys()
print(type(k))
print(k)
<class 'dict_keys'>
dict_keys(['one', 'two', 'three'])
# values: 同理,一个可迭代的结构
v = d.values()
print(type(v))
print(v)
<class 'dict_values'>
dict_values([1, 2, 3])
# get: 根据制定键返回相应的值, 好处是,可以设置默认值
d = {"one":1, "two":2, "three":3}
print(d.get("on333"))
# get默认值是None,可以设置
print(d.get("one", 100))
print(d.get("one333", 100))
#体会以下代码跟上面代码的区别
print(d['on333'])
None
1
100
---------------------------------------------------------------------------
KeyError Traceback (most recent call last)
<ipython-input-22-ab27a780e6a8> in <module>
9
10 #体会以下代码跟上面代码的区别
---> 11 print(d['on333'])
KeyError: 'on333'
# fromkeys: 使用指定的序列作为键,使用一个值作为字典的所有的键的值
l = ["eins", "zwei", "drei"]
# 注意fromkeys两个参数的类型
# 注意fromkeys的调用主体
d = dict.fromkeys(l, "hahahahahah")
print(d)
{'eins': 'hahahahahah', 'zwei': 'hahahahahah', 'drei': 'hahahahahah'}