Python-可变类型与不可变类型
可变类型
可以变化的,列表和字典
利用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)