• 列表的操作


    # names="Alex Jack Bob Tom"
    import copy
    names = ["Alex", "Jack", "Bob", "Tom","Roman"]
    print(names)
    '''
    "Alex", "Jack", "BOb", "Tom"
    0 1 2 3
    '''
    print(names[1:3]) # 顾头不顾尾'Jack', 'BOb'(只包括头部不包括尾部)
    print(names[-1]) # 从后往前取
    print(names[-3:-1]) # 从后往前取但是是从左往右数'Jack', 'BOb'
    '''
    "Alex", "Jack", "Bob", "Tom"
    -3 -2 -1 0
    '''
    '''
    print(names[-2:0])但是要想取到最后一个数据,这个写法是错误的
    这样写才对:
    print(names[-2:])表示取最后两个数据 结果为'BOb', 'Tom'
    同理这样也可以:
    print(names[0:3])表示取前三个数据
    print(names[:3])也表示取前三个数据
    '''
    # 数据的追加append(在最后加上数据)
    # names.append("Last")
    # 数据的插入
    names.insert(1, "Jerry")
    print(names) # 结果为['Alex', 'Jerry', 'Jack', 'BOb', 'Tom']
    '''
    数据的更换
    names[2]="New name"
    print(names) 结果为['Alex', 'Jerry', 'New name', 'BOb', 'Tom']
    数据的删除
    第一种方法: names.remove("要删除的数据")
    比如: names.remove("Jerry")
    第二种方法: del names[要删除的下标]
    比如:del names[2]
    第三种方法: names.pop() #不输入下标就删掉了最后一个数据
    输入了下标就删除对应下标的数据
    此时names.pop(i)=del names[i] 效果一样
    '''
    print(names)
    print(names.index("Bob")) # 用index()查找“Bob”的位置
    # 结果返回了3,
    # 发现“Bob”恰好在下标3 ['Alex', 'Jerry', 'Jack', 'Bob', 'Tom']
    '''
    统计列表里有多少重复的数据 count()
    print(names.count("重复的数据"))
    对列表数据进行排序(按特殊字符,数字,字母大写,字母小写的顺序依次来的)
    names.sort()
    列表的合并,extend()
    names2=[1,2,3,4]
    names.extend(names2)#这里names2的数据加入到names里了
    print(names) 结果['Alex', 'Jerry', 'Jack', 'Bob', 'Tom', 1, 2, 3, 4]
    列表的删除 del 列表名
    names2=[1,2,3,4]
    names.extend(names2)
    del names2
    print(names,names2) #结果NameError: name 'names2' is not defined
    列表的复制 copy()
    如: names2=names.copy()
    列表里还可以包含列表(子列表)
    names=['Alex', 'Jerry',['aaa','bbb','ccc'], 'New name', 'BOb', 'Tom']
    print(names)
    print(names[2]) #['aaa', 'bbb', 'ccc']
    子列表的赋值:
    names[2][0]="AAA"#父列表第三个['aaa','bbb','ccc'],子列表['aaa', 'bbb', 'ccc']第一个数据
    '''
    '''
    names = ['Alex', 'Jerry', ['aaa', 'bbb', 'ccc'], 'New name', 'BOb', 'Tom']
    names2 = names.copy()
    names2[1]="JERRY"
    names[2][0] = "AAA"
    print(names)
    print(names2) # ['Alex', 'Jerry', ['AAA', 'bbb', 'ccc'], 'New name', 'BOb', 'Tom']
    # copy()只是浅copy(很少用到),实际上子列表存在不同于父列表的内存地址里,浅copy只复制了父列表的第一层,
    # 子列表的内存地址还是原来的。这样导致列表的复制不全(不独立)
    # 比如上例,names的子列表为 ['aaa', 'bbb', 'ccc'],copy给names2,然后把names的子列表第一项改为"AAA",按理说names2不会改,
    #可是names2也跟着改了(子列表的内存地址还是原来的),因此copy()后的子列表是不独立的!!!(父列表还是完全独立的!)
    # 像a=xxx b=a a=yyy 之类简单的字符串或数字 b的值不会变成yyy,这样是完全独立
    #但是对于列表来说,像上述赋值这内存地址是完全一样的,即完全不独立
    #总之,浅copy的子列表内存地址与原来的一样,一旦对其进行改动则复制前后的子列表都会改动;
    #一个列表直接赋值给另一个列表,内存地址不变,即完全不独立;字符串或数字则内存地址改变,完全独立
    '''
    '''
    names = ['Alex', 'Jerry', ['aaa', 'bbb', 'ccc'], 'New name', 'BOb', 'Tom']
    names2 = copy.deepcopy(names)
    names2[1]="JERRY"
    names2[2][0] = "AAA"
    print(names)
    print(names2)这个例子为深copy,即copy之后的列表与原列表完全独立,需要在开头 import copy
    '''
    '''
    列表的循环
    for i in names:
    print(i)
    print(names[0:-1:2])
    这里的冒号可以省略,变为names[::2],效果一样
    '''

  • 相关阅读:
    HTTP客户端
    获取IP地址和域名
    SQL语句、PL/SQL块和SQL*Plus命令之间的区别
    oracle中的游标
    oracle表问题
    精简版web浏览器
    oracle的存储过程
    数据库中的视图
    第一次作业
    折半查找
  • 原文地址:https://www.cnblogs.com/gilgamesh-hjb/p/7229306.html
Copyright © 2020-2023  润新知