主要涉及列表的潜复制(第二层受后面修改的影响)和深复制(不受后面修改的影响)

代码如下

# coding=utf-8
# Author: RyAn Bi
import copy
names = ['A','B','C','D']
'''
print(names)
print(names[0]) #从0开始记录
print(names[1],names[2])
print(names[1:3]) #不包含3
print(names[3])
print(names[-1]) #倒着数
print(names[-2:]) #取-2到-1,由于没有办法包含-1,所以不写 names.append('F') #在最后追加一个F
names.insert(1,'E') #在1的位置,加入E,之后依次后挪
print(names) names[2] = 'G' #修改了2号的名字
print(names) names.remove('G') #删除G
print(names)
del names[1] #删除下标1
print(names)
names.pop()#默认删除最后一个,如果加入下标1,相当于删除下标1,等同于del names[1]
print(names)
print(names.index('A')) #找A的位置
print(names[names.index('A')]) #找到A的位置,并打印A
names.insert(1,"A")
print(names.count('A')) #统计A的数量
#names.clear() #清空列表
names.reverse() #翻转列表
print(names)
names.sort() #排序,默认顺序(ask码中的排序)
print(names)
names2=[1,2,3,5] names.extend(names2) #将names和names2合并
print(names,names2)
del names2 #删除name2表
'''
names3 = ['A','B',['bb','cc'],'C','D']
names2 = names3.copy() # 复制一份names,潜复制,只能复制第一层,之后,第一层改动不会变
names4 = names3 # 完全一样,后面改动,也会改动
names5 = copy.deepcopy(names3) #调用copy模块里的copy,之后怎么改动,哪一层都不会变
print(names3)
print(names2)
names3[3]='第' #修改下标3,只在names3中改,names2不改(潜copy,第一层直接copy)
names3[2][0]='毕' #修改下标2中的下标1,这个name3和那么2中都改(潜copy,列表实际上内存中的一个指针,你只copy了地址),第二层的不会被copy
print('name3:',names3) # 原始值,改动后
print('name2:',names2) # 潜copy,第一层不变,第二层由于指向内存里内容变了,所以变了
print('name4:',names4) #赋值复制,第一层和第二层都变了
print('name5:',names5) #深copy,必须调用copy模块,第一层和第二层都不变 for i in names2:
print(i) print(names2[0:-1:2]) #打印偶数位
print(names2[::2]) #同上

python学习,day2:列表的复制的更多相关文章

  1. Python学习02 列表 List

    Python学习02 列表 List Python列表 List Python中的列表(List)用逗号分隔,方括号包围(comma-separated values (items) between ...

  2. Python学习3——列表和元组

    一.通用序列操作——索引.切片.相加.相乘.成员资格检查 1.索引,正序从0开始为第一个元素,逆序从-1开始,-1为最后一个元素 >>> greeting[0] 'h' >&g ...

  3. python学习笔记——列表生成式与生成器

    1.列表生成式(List Comprehensions) python中,列表生成式是用来创建列表的,相较于用循环实现更为简洁.举个例子,生成[1*1, 2*2, ... , 10*10],循环用三行 ...

  4. Python基础之列表深浅复制和列表推导式

    一.列表深浅复制: 浅拷贝内存图如下: 深拷贝内存图如下: 二.列表推导式: 实例: """ 列表推导式 练习:exercise01 """ ...

  5. python学习之列表的定义以及增删改查

    列表定义: >>> name['lily','lucy','tom'] >>> nums = [11,22,33,'100','lily'] #python中的列表 ...

  6. python学习day2

    一.模块初识 python模块 模块让你能够有逻辑地组织你的Python代码段. 把相关的代码分配到一个 模块里能让你的代码更好用,更易懂. 模块也是Python对象,具有随机的名字属性用来绑定或引用 ...

  7. Python学习-day2

    这周时间充裕,把第一周的两个作业登陆验证和三级菜单做完后又用零零散散的时间看完了第二周的课程,不得不说老男孩这个教育方式感觉还是不错的,其实说白了就是花钱找个人监督自己学习呗,而且还强行让我们养成一些 ...

  8. python学习之列表语法

    1.列表 1 list.append(obj)在列表末尾添加新的对象2 list.count(obj)统计某个元素在列表中出现的次数3 list.extend(seq)在列表末尾一次性追加另一个序列中 ...

  9. Python学习三|列表、字典、元组、集合的特点以及类的一些定义

    此表借鉴于他人 定义 使用方法 列表 可以包含不同类型的对象,可以增减元素,可以跟其他的列表结合或者把一个列表拆分,用[]来定义的 eg:aList=[123,'abc',4.56,['inner', ...

  10. day3.python 学习之列表

    python中列表用[ ]表示, list =  [ ] #表示一个空列表 1.list = [ 'A','B','C',‘D’] print(list[0]) # 表示打印出列表中的第一个元素,列表 ...

随机推荐

  1. java基础之JDBC八:Druid连接池的使用

    基本使用代码: /** * Druid连接池及简单工具类的使用 */ public class Test{ public static void main(String[] args) { Conne ...

  2. Topic modeling【经典模型】

    http://www.cs.princeton.edu/~blei/topicmodeling.html Topic models are a suite of algorithms that unc ...

  3. 17-pow(c++)

    C++中有封装的pow()可以直接调用,头文件math,同时对函数进行了重载,支持多种参数格式: double pow (double base , double exponent); float p ...

  4. ROS naviagtion analysis: move_base

    博客转载自:https://blog.csdn.net/u013158492/article/details/50483123 这是navigation的第一篇文章,主要通过分析ROS代码级实现,了解 ...

  5. 932F Escape Through Leaf

    传送门 题目大意 https://www.luogu.org/problemnew/show/CF932F 分析 我们可以从叶子向根每次插入b和ans 所以我们不难发现就是相当于插入线段 于是李超树+ ...

  6. vue.js的一些模板指令简述

    1.模板指令都是写在<template></template>html里面   v-text : value是什么就显示什么,如果value里面有html的标签,也会直接显示出 ...

  7. 内存中DataTable去除重复行

    删除内存中DataTable表的重复行 假设在内存中(不是数据库中)有两个表: 表一:TableA Name Phone 张三 123456 李四 123457 王五 1234568 表二:Table ...

  8. poj 1611 The Suspects(第一道并查集)

    题意: 有N个学生,编号为0-n-1,现在0号学生感染了非典,凡是和0在一个社团的人就会感染, 并且这些人如果还参加了别的社团,他所在的社团照样全部感染,社团个数为m,求感染的人数. 输入: n代表人 ...

  9. oracle数据库之数据插入、修改和删除

    作为一合格的测试人员对数据库的单表查询.多表查询.分组查询.子查询等等这些基本查询方法还是要会的.不然到企业中,容易被一些人鄙视,或者说如果数据库学不好,表查不明白,那么对自己能力来说也是一种侮辱,因 ...

  10. HDU 3723 Delta Wave (高精度+calelan数)

    题意:给定一个图,问你只能向上向下,或者平着走,有多少种方法可以走到最后一个格. 析:首先先考虑,如果没有平的情况就是calelan数了,现在有平的情况,那么就枚举呗,因为数很大,所以要用高精度. 答 ...