系统学习python第六天学习笔记

1.补充

1.列表方法补充

  • reverse,反转。

    v1 = [1,2,3111,32,13]
    print(v1)
    v1.reverse()
    print(v1)
  • sort,排序

    v1 = [11,22,3111,32,13]
    print(v1)
    
    # v1.sort(reverse=False) # 从小到大(默认)
    # v1.sort(reverse=True) # 从大到小
    # print(v1)

2.字典方法补充

  • keys/values/items

  • get

    • 判断字典中是否存在键,不存在则返回None,存在则取对应的值并返回赋值给变量
    info = {'k1':'v1','k2':'v2'}
    
    # v1 = info['k11111']
    # v2 = info.get('k1111') # None就是Python中的空
    # v3 = info.get('k1111',666)
    # print(v2)
    
    # None数据类型,改类型表示空(无任何功能,专门用于提供空值)
  • pop

    • 删除,也可以用del删除
    info = {'k1':'v1','k2':'v2'}
    result = info.pop('k2')
    print(info,result)
    
    del info['k1']
  • update

    • 不存在,则添加/存在,则更新
    info = {'k1':'v1','k2':'v2'}
    
    # 不存在,则添加/存在,则更新
    info.update({'k3':'v3','k4':'v4','k2':666})
    print(info)

3.判断一个字符串中是否有敏感字符?

  • str

    v = "Python全栈21期"
    
    if "全栈" in v:
        print('含敏感字符')
  • list/tuple

    v = ['alex','oldboy','藏老四','利奇航']
    
    if "利奇航" in v:
        print('含敏感')
    
  • dict

    v = {'k1':'v1','k2':'v2','k3':'v3'}
    
    # 默认按照键判断,即:判断x是否是字典的键。
    if 'x' in v:
        pass 
    
    # 请判断:k1 是否在其中?
    if 'k1' in v:
        pass
    # 请判断:v2 是否在其中?
    # 方式一:循环判断
    flag = '不存在'
    for v in v.values():
        if v == 'v2':
            flag = '存在'
    print(flag)
    # 方式二:
    if 'v2' in list(v.values()): # 强制转换成列表 ['v1','v2','v3']
          pass
    # 请判断:k2:v2 是否在其中?
    value = v.get('k2')
    if value == 'v2':
        print('存在')
    else:
        print('不存在')
    
  • 练习题

    # 让用户输入任意字符串,然后判断此字符串是否包含指定的敏感字符。
    
    char_list = ['利奇航','堂有光','炸展会']
    content = input('请输入内容:') # 我叫利奇航  / 我是堂有光  / 我要炸展会
    
    success = True
    
    for v in char_list:
        if v in content:
            success = False
            break
    
    if success:
      print(content)
    else:
        print('包含铭感字符')
    
    # 示例:
    # 1. 昨天课上最后一题
    # 2. 判断 ‘v2’ 是否在字典的value中 v = {'k1':'v1','k2':'v2','k3':'v3'} 【循环判断】
    # 3. 敏感字

注意点:

  • 可设置一个标签来判断状态

    char_list = ['利奇航','堂有光','炸展会']
    content = input('请输入内容:')
    success = True  # 标签判断状态
    for v in char_list:
        if v in content:
            success = False
            break
    if success:
        print(content)
    else:
        print('包含铭感字符')

2.集合 set

  • 特点

    • 无序
    • 无重复
  • 空集合的创建

    v = {1,2,3,4,5,6,99,100}
    
    # 疑问:v = {}
    """
    None
    int
        v1 = 123
        v1 = int() --> 0
    bool
        v2 = True/False
        v2 = bool() -> False
    str
        v3 = ""
        v3 = str()
    list
        v4 = []
        v4 = list()
    tuple
        v5 = ()
        v5 = tuple()
    dict
        v6 = {}
        v6 = dict()
    set
        v7 = set()
    """
  • 集合独有功能

    • add 添加

      # v = {1,2}
      # v.add('Lishaoqi')
      # v.add('Lishaoqi')
      # print(v)
    • discard 删除

      # v = {1,2,'李邵奇'}
      # v.discard('李邵奇')
      # print(v)
    • update 批量添加

      # v = {1,2,'李邵奇'}
      # v.update({11,22,33})
      # print(v)
    • intersection 交集

      # v = {1,2,'李邵奇'}
      # result = v.intersection({1,'李邵奇','小黑'})
      # print(result)
    • union 并集

      # v = {1,2,'李邵奇'}
      # result = v.union({1,'李邵奇','小黑'})
      # print(result)
    • difference 差集

      # v = {1,2,'李邵奇'}
      # result = v.difference({1,'李邵奇','小黑'}) # v中有且{1,'李邵奇','小黑'}没有
      # print(result)
      
      # v1 = {1,'李邵奇','小黑'}
      # result1 = v1.difference({1,2,'李邵奇'})
      # print(result1)
    • symmetric_difference 对称差集

      # v = {1,2,'李邵奇'}
      # result = v.symmetric_difference({1,'李邵奇','小黑'})
      # print(result)

    注意:交集、并集和差集括号内传入参数时,可以同样是集合,也可以是列表和元组

  • 公共功能

    • len

      v = {1,2,'李邵奇'}
      print(len(v))
    • for循环

      v = {1,2,'李邵奇'}
      for item in v:
          print(item)
    • 索引【无】

    • 步长【无】

    • 切片【无】

    • 删除【无】

    • 修改【无】

  • 嵌套问题

    • 哈希问题

    列表/字典/集合:不能放在集合中,也不能作为字典的key(unhashable)

    # 1. 列表/字典/集合 -> 不能放在集合中+不能作为字典的key(unhashable)
    # info = {1, 2, 3, 4, True, "国风", None, (1, 2, 3)}
    # print(info)
    # 2. hash -> 哈希是怎么回事?
    # 因为在内部会将值进行哈希算法并得到一个数值(对应内存地址),以后用于快速查找。
    
    # 3. 特殊情况
    # info = {0, 2, 3, 4, False, "国风", None, (1, 2, 3)}
    # print(info)
    # 此时不打印False
    
    # info = {
    #     1:'alex',
    #     True:'oldboy'
    # }
    # 此时没有key为True的键,而是'oldboy'将'alex'覆盖
    # print(info)

3.内存相关

  • 示例一

    v1 = [11,22,33]
    v2 = [11,22,33]
    
    v1 = 666
    v2 = 666
    
    v1 = "asdf"
    v2 = "asdf"
    
    # 按理 v1 和 v2 应该是不同的内存地址。特殊:
    1. 整型:  -5 ~ 256
    2. 字符串:"alex",'asfasd asdf asdf d_asdf '   ----"f_*" * 3  - 重新开辟内存。

特殊:

# 按理 v1 和 v2 应该是不同的内存地址。特殊:
1. 整型:  -5 ~ 256
2. 字符串:"alex",'asfasd asdf asdf d_asdf '
    ----"f_*" * 3  - 重新开辟内存。
  • 示例二:

    v1 = [11,22,33,44]
    v1 = [11,22,33]
  • 示例三:

    v1 = [11,22,33]
    v2 = v1 
    
    # 练习1 (内部修改)
    v1 = [11,22,33]
    v2 = v1
    v1.append(666)
    print(v2) # 含 666
    
    # 练习2:(重新赋值)
    v1 = [11,22,33]
    v2 = v1
    v1 = [1,2,3,4]
    print(v2)
    
    # 练习3:(重新赋值)
    v1 = 'alex'
    v2 = v1
    v1 = 'oldboy'
    print(v2)
  • 示例四

    v = [1,2,3]
    values = [11,22,v]
    
    # 练习1:
    """
    v.append(9)
    print(values) # [11,22,[1,2,3,9]]
    """
    # 练习2:
    """
    values[2].append(999)
    print(v) # [1, 2, 3, 999]
    """
    # 练习3:
    """
    v = 999
    print(values) # [11, 22, [1, 2, 3]]
    """
    # 练习4:
    values[2] = 666
    print(v) # [1, 2, 3]
  • 示例五

    v1 = [1,2]
    v2 = [2,3]
    
    v3 = [11,22,v1,v2,v1]
    
  • 查看内存地址

    """
    v1 = [1,2,3]
    v2 = v1
    v1.append(999)
    print(v1,v2)
    print(id(v1),id(v2))
    """
    
    """
    v1 = [1,2,3]
    v2 = v1
    print(id(v1),id(v2))
    v1 = 999
    print(id(v1),id(v2))
    """
  • 问题: == 和 is有什么区别?

    v1 = [1, 2, 3, 4]
    v2 = [1, 2, 3, 5, 6]
    v1 == v2  ----> False
    v1 is v2  ----> False
    
    v1 = [1, 2]
    v2 = [1, 2]
    v1 == v2  ----> True
    v1 is v2  ----> False
    
    v1 = [1, 2, 3]
    v2 = v1
    v1 == v2  ----> True
    v1 is v2  ----> True
    • == 用于比较值是否相等。
    • is 用于比较内存地址是否相等。
上一篇:python 第六天


下一篇:shell排序算法