Python-可变类型与不可变类型

可变类型

可以变化的,列表和字典

利用id()函数 查看内存地址

内存地址变化即不可变类型。

内存地址不变化即可变类型

不可变类型

不可以变化的,字符串和数字

字符串内置方法

  1. 索引取值
  2. 索引切片
  3. 成员运算
  4. for循环
  5. len长度
  6. strip 去掉空格
  7. lstrip/rstrip
  8. startswith/endswith
  9. split
  10. join
  11. count
  12. find/index
  13. center/ljust/rjust

列表的内置方法

  1. 索引取值/修改值
  2. 索引切片
  3. 成员运算
  4. for循环
  5. len长度
  6. append 添加元素
  7. sort 排序
  8. reverser 反转元素
  9. copy
  10. extend
  11. clear
  12. remove
  13. insert

字典的内置方法

  1. 按key取值/修改值/增加值
  2. keys
  3. values
  4. items
  5. get
  6. setdefault
  7. 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)
posted @ 2019-09-02 14:57  GeminiMp  阅读(334)  评论(0编辑  收藏  举报