python可变类型和不可变类型_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)

表情包
插入表情
评论将由博主筛选后显示,对所有人可见 | 还能输入1000个字符
相关推荐
©️2020 CSDN 皮肤主题: 数字20 设计师:CSDN官方博客 返回首页