可变类型
可以变化的,列表和字典
利用id()函数 查看内存地址
内存地址变化即不可变类型。
内存地址不变化即可变类型
不可变类型
不可以变化的,字符串和数字
字符串内置方法
索引取值
索引切片
成员运算
for循环
len长度
strip 去掉空格
lstrip/rstrip
startswith/endswith
split
join
count
find/index
center/ljust/rjust
列表的内置方法
索引取值/修改值
索引切片
成员运算
for循环
len长度
append 添加元素
sort 排序
reverser 反转元素
copy
extend
clear
remove
insert
字典的内置方法
按key取值/修改值/增加值
keys
values
items
get
setdefault
update
常用数据类型内置方法
1
2
3
4
5
6
7
8
9
10
11
字符串
索引取值
成员运算
循环
len
count
strip lstrip rstrip
split
join
find index
startswith endswith
center ljust rjust
列表
索引取 修改值
成员运算
循环
len
sort
extend
copy
append insert
reverse
crear remove
字典
key取值修改增值
成员运算
循环
keys
values
items
get
setdefault
update
列表
字典
增
append/insert/extend/copy
按key赋值(num["qq"]=123) copy
删
pop/remove/clear/del
按key删除(del num["qq"]/num.pop("qq")) clear
改
索引修改
按key修改(num["name"]="老王") update
查
索引取值/count/len/index/sort
get/keys/values/items/setdefault
1. 有如下值集合 [11,22,33,44,55,66,77,88,99,90...],将所有大于 66 的值保存至字典的第一个key中,将小于 66 的值保存至第二个key的值中
即: {'k1': 大于66的所有值, 'k2': 小于66的所有值}
lt = [11,22,33,44,55,66,77,88,99,90]
l1 = []
l2 = []
dic = {}
for i in lt:
if i > 66:
l1.append(i)
else:
l2.append(i)
dic["k1"] = l1
dic["k2"] = l2
print(dic)
2. 统计s='hello alex alex say hello sb sb'中每个单词的个数
结果如:{'hello': 2, 'alex': 2, 'say': 1, 'sb': 2}
s = 'hello alex alex say hello sb sb'
dic = {}
for i in s.split():
dic[i] = s.count(i)
print(dic)
3. 写代码,有如下变量,请按照要求实现每个功能
name = " aleX"
# 1) 移除 name 变量对应的值两边的空格,并输出处理结果
# 2) 判断 name 变量对应的值是否以 "al" 开头,并输出结果
# 3) 判断 name 变量对应的值是否以 "X" 结尾,并输出结果
# 4) 将 name 变量对应的值中的 “l” 替换为 “p”,并输出结果
# 5) 将 name 变量对应的值根据 “l” 分割,并输出结果。
# 6) 请输出 name 变量对应的值的第 2 个字符?
# 7) 请输出 name 变量对应的值的前 3 个字符?
# 8) 请输出 name 变量对应的值的后 2 个字符?
# 9) 请输出 name 变量对应的值中 “e” 所在索引位置?
# 10) 获取子序列,去掉最后一个字符。如: oldboy 则获取 oldbo。
name = " aleX"
print(name.strip())
print(name.startswith("al"))
print(name.endswith("X"))
print(name.replace("l","p"))
print(name.split("l"))
print(name[1])
print(name[0:4])
print(name[-2:])
print(name.index("e"))
print(name.rstrip("X"))
4. 假设有一个文件test.txt,内有如下内容
l=[
{'name':'alex','age':84},
{'name':'oldboy','age':73},
{'name':'egon','age':18},
]
需求:
1. 读取文件内容
2. 计算这三个人的年龄总和
num = 0
with open("test.txt","r") as f:
data = f.readlines()
for i in data:
if i == "l=[\n" or i == "]":
continue
else:
list_txt = i.lstrip("\n").rstrip("\n,")
dic = eval(list_txt)
num += dic["age"]
print(num)