05 常用技巧介绍(列表、元组、字典)

2019-10-28  本文已影响0人  武漂的小丙

1 列表操作

li = ['alex', 'wusir', 'egon', '女神', 'taibai']

# 在最后的位置增加
li.append('当当')
print(li)
# 迭代加到最后的位置
li.extend('昊天')
print(li)
# 在‘女神’后面加一个123
li.insert(4,123)
print(li)
# 按索引删除,默认删除最后一个
li.pop()
print(li)
li.pop(1)
print(li)
# 按元素删除,有重复元素,删除索引最小的一个
li.append('当当')
print(li)
li.remove('当当')
print(li)

# 清空列表
li.clear()
print(li)
'''输出结果如下:
['alex', 'wusir', 'egon', '女神', 'taibai', '当当']
['alex', 'wusir', 'egon', '女神', 'taibai', '当当', '昊', '天']
['alex', 'wusir', 'egon', '女神', 123, 'taibai', '当当', '昊', '天']
['alex', 'wusir', 'egon', '女神', 123, 'taibai', '当当', '昊']
['alex', 'wusir', '女神', 123, 'taibai', '当当', '昊']
['alex', 'wusir', '女神', 123, 'taibai', '当当', '昊', '当当']
['alex', 'wusir', '女神', 123, 'taibai', '昊', '当当']
[]
'''

删除列表

li = ['alex', 'wusir', 'egon', '女神', 'taibai', '当当']
# 从0开始删除前两个:
del li[0:2]
print(li)

'''输出结果如下:
['egon', '女神', 'taibai', '当当']
'''

赋值

li = ['alex', 'wusir', 'egon', '女神', 'taibai', '当当']
li[0] = '男神'
print(li)
li[0] = [1,2,3]
print(li)
# 将从0开始的前两个拿出来,然后迭代添加进去
li[0:2] = '阿里巴巴'
print(li)
li[0,4] = [123,'春哥', 'dddd']
print(li)

'''输出结果如下:
['男神', 'wusir', 'egon', '女神', 'taibai', '当当']
[[1, 2, 3], 'wusir', 'egon', '女神', 'taibai', '当当']
['阿', '里', '巴', '巴', 'egon', '女神', 'taibai', '当当']
[123, '春哥', 'dddd', 'egon', '女神', 'taibai', '当当']
'''

查询

for i in li:
    print(i)
print(li[0:2])

公共方法:

len(li)
li = ['阿', '里', '巴', '巴', 'egon', '女神', 'taibai', '巴巴']
li.count('巴')
li = ['阿', '里', '巴', '巴', 'egon', '女神', 'taibai', '巴巴']
# 返回第一次出现的索引
li.index('巴')
# 正向排序
li.sort()
# 反向排序
li.sort(reverse=True)
li = [123, '春哥', 'dddd', 'egon', '女神', 'taibai', '当当']
li.reverse()
# reverse反转的是自身
print(li)
'''输出结果如下:
['当当', 'taibai', '女神', 'egon', 'dddd', '春哥', 123]
'''

列表嵌套:

li = ['taibai', '武藤兰', '苑昊', ['alex','egon',89],23]
# 打印一个“藤”
print(li[1][1])

# 将‘taibai’改为‘Taibai’,即首字母大写
name = li[0].capitalize()
li[0] = name
print(li)

2 元组操作

tu = (1, 2, 3, 'alex', [2, 3, 4, 'taibai'], 'egon')
# 找到alex
print(tu[3])
# 分片
print(tu[0:4])
# 循环
for i in tu:
    print(i)
# 将taibai 改成 TAIBAI
tu[4][3] = tu[4][3].upper()
print(tu)
# 添加一个元素‘sb’
tu[4].append('sb')
print(tu)


# str ---》 list 用 split
# list ---》 str 用 jion
# list的元素都必须是字符串
s = 'alex'
s1 = '__'.join(s)
tu = ( 'alex', 'egon')
s2 = '__'.join(tu)
print(s1)
print(s2)

3 字典

python唯一映射数据类型

dic1 = {
    'name': ['大猛', '小孟'],
    'py9': [{'num':71, 'avg_age':18}],
    True:1,
    (1,2,3): 'wuyiyi',
    # 元组里面带有list也是不行的
    # (12,[1,2]): '行不行',
    2: '儿歌'
}
print(dic1)

# 删
print(dic1.pop('py9')) # 有则按键删除, 返回此键的value
print(dic1.pop('py9',"没有此建")) # 没有此建,可以设置返回值
print(dic1.popitem()) # 随机删除,有返回值 元组(里面是删除的键值)
print(dic1)

# 查
print(dic1.keys())
print(dic1.values())
print(dic1.items())

遍历的技巧:

a = 1
b = 2
# a,b 地址互换
a,b = b,a
print (a, b)
a, b = [1, 2]
print (a, b)
a, b = [1, 2], [2, 3]
print (a, b)
a, b = (1, 2)
print (a, b)

for k,v in dic1.items():
    print (k, v)

键值不报错的方式:

v1 = dic1['name']

v2 = dic1['name1'] # 报错

print(dic1.get('name1', '没有这个键'))

输入一段字符串,只将字母转成“空格”

info = input(">>>")  #fhdalf1232ddfqer12dfjal13
for i in info:
    if i.isalpha():
        info = info.replace(i," ")
l = info.split()
print(len(l))

ps:“for i in info:”在这一句的时候info已经载入for循环中了,因此循环在里面修改info的时候,也不会更改for循环的执行情况

4 作业

循环打印列表:“(1, 2, 3, 'alex', [2, 3, 4, 'taibai'], 'egon')” , 要求子列表的元素也能循环打印,即如下所示:

1, 
2, 
3, 
'alex', 
2, 
3, 
4, 
'taibai', 
'egon'

解答如下:

# 采用递归的方式迭代打印元素
def iteratorPrint(it):
    for item in it:
        if isinstance(item, Iterable) and  not isinstance(item, str):
            iteratorPrint(item)
        else:
            print(item)


iteratorPrint(tu)

5 小结

5.1 = 、==、 is

image-20191027133417887.png image-20191027133213542.png

5.2 内存地址

image-20191027133311061.png

5.3 编码说明

s1 = 'alex'
s11 = s1.encode('utf-8')
print(s11)
s2 = '中国'
# utf-8 是三个字节表示一个汉字
s21 = s2.encode('utf-8')
print(s21)
# gbk 是两个字节表示一个汉字
s22 = s2.encode('gbk')
print(s22)
上一篇下一篇

猜你喜欢

热点阅读