列表,元组等学习笔记小结

例1:列表切片
  names = ["zhangsna","lisi","wangwu","zhaoliu"]
  print(names[1])    #读取第2个元素,列表的下表是从0开始的   lisi
  print(names[0],names[2]) #读取第1个,第3个元素       zhangsna wangwu
  print(names[0:])   #读取下标0及往后的所有元素     ['zhangsna', 'lisi', 'wangwu', 'zhaoliu']
  print(names[1:])   #读取下标1及往后的所有元素    ['lisi', 'wangwu', 'zhaoliu']
  print(names[1:2])   #读取下标1及下标2前的所有元素   ['lisi']
  print(names[1:3])   #读取下标1及下标3前不包括3,这叫切片 ['lisi', 'wangwu']
  print(names[-1])   #读取最后1个元素      zhaoliu
  print(names[-3:])   #读取倒数第三个往后的所有数据;   ['lisi', 'wangwu', 'zhaoliu']
  print(names[-3:-1])   #顺序都是从左往右的      ['lisi', 'wangwu']
  print(names[:3])       #等于names[0:3]       ['zhangsna', 'lisi', 'wangwu']
  print(names[0:-1:2])        #步长2,隔开切片      ["zhangsna","wangwu"]
  print(names[::2])   #等于names[0:-1:2]      ["zhangsna","wangwu"]
 
 
 列2:列表的追加:(追加是追加在末尾)
  names = ["zhangsna","lisi","wangwu","zhaoliu"]
  print(names)          
  names.append("kitty")
  print(names)
 输出结果:
  ['zhangsna', 'lisi', 'wangwu', 'zhaoliu']
  ['zhangsna', 'lisi', 'wangwu', 'zhaoliu', 'kitty']
 
 列3:插入到指定位置:
  names = ["zhangsna","lisi","wangwu","zhaoliu"]
  print(names)
  names.insert(1, "kitty")
  print(names)
 输出结果:
  ['zhangsna', 'lisi', 'wangwu', 'zhaoliu']
  ['zhangsna', 'kitty', 'lisi', 'wangwu', 'zhaoliu']
 
 列4:修改列表内容;
  names = ["zhangsna","lisi","wangwu","zhaoliu"] 
  print(names)
  names[1] = "Brace"
  print(names)
 输出结果:
  ['zhangsna', 'lisi', 'wangwu', 'zhaoliu']
  ['zhangsna', 'Brace', 'wangwu', 'zhaoliu']
 
 
 列5:列表内容的删除:
 删除1:
  names = ["zhangsna","lisi","wangwu","zhaoliu"] 
  print(names)
  names.remove("lisi")
  print(names)         #输出:['zhangsna', 'wangwu', 'zhaoliu']
 删除2:
  print(names)
  del names[1]         #指定下标删除
  print(names)         #输出:['zhangsna', 'wangwu', 'zhaoliu']
 删除3:
  names = ["zhangsna","lisi","wangwu","zhaoliu"] 
  print(names)
  names.pop()          #默认不输入下标,删除最后一个
  print(names)         #输出:['zhangsna', 'lisi', 'wangwu']
 删除4:
  print(names)
  names.pop(1)         #指定下标删除
  print(names)         #['zhangsna', 'wangwu', 'zhaoliu']
 列6:查找元素的下标:
  names = ["zhangsna","lisi","wangwu","zhaoliu"]
  print(names.index("lisi"))      #输出:1
  print(names[names.index("lisi")])    #输出:lisi
 
 
 列7:列表相同元素个数统计: 
  names = ["zhangsna","lisi","wangwu","zhaoliu","lisi"]
  print(names.count("lisi"))      #输出:2
 
 列8: 列表元素的清除
  names = ["zhangsna","lisi","wangwu","zhaoliu","lisi"]
  names.clear()
  print(names)          #输出:[]
 
 列9:列表元素的反转:
  names = ["zhangsna","lisi","wangwu","zhaoliu","lisi"]
  names.reverse()
  print(names)          #输出:['lisi', 'zhaoliu', 'wangwu', 'lisi', 'zhangsna']
 
 列10:列表元素的排序
  names = ["zhangsna","lisi","wangwu","zhaoliu","lisi"]
  names.sort()
  print(names)          #输出:['lisi', 'lisi', 'wangwu', 'zhangsna', 'zhaoliu']
 
 
 列11:列表元素合并: 
  names = ["zhangsna","lisi","wangwu","zhaoliu","lisi"]
  names1 = [1,2,3,4,5]
  names.extend(names1)
  print(names)          #输出:['zhangsna', 'lisi', 'wangwu', 'zhaoliu', 'lisi', 1, 2, 3, 4, 5]
  print(names1)          #输出:[1, 2, 3, 4, 5]
 
 
 列12:列表元素浅复制(浅拷贝):只拷贝第一层,更深层次不拷贝,和copy.copy一样
 
 列1:
  names = ["zhangsna","lisi","wangwu","zhaoliu","lisi"]
  names2 = names.copy()
  print(names)
  print(names2)
  names[2]="李李"
  print(names)
  print(names2)
 
 输出结果:
  ['zhangsna', 'lisi', 'wangwu', 'zhaoliu', 'lisi']
  ['zhangsna', 'lisi', 'wangwu', 'zhaoliu', 'lisi']
  ['zhangsna', 'lisi', '李李', 'zhaoliu', 'lisi']
  ['zhangsna', 'lisi', 'wangwu', 'zhaoliu', 'lisi']
  
 列2:
  names = ["zhangsna","lisi","wangwu",["a","b","c"],"zhaoliu","lisi"]
  names2 = names.copy()
  print(names)
  print(names2)
  names[2]="李李"
  names[3][1]="bbbbb"
  names[3][2]="ccccc"
  print(names)
  print(names2)
 
 输出结果:
  ['zhangsna', 'lisi', 'wangwu', ['a', 'b', 'c'], 'zhaoliu', 'lisi']
  ['zhangsna', 'lisi', 'wangwu', ['a', 'b', 'c'], 'zhaoliu', 'lisi']
  ['zhangsna', 'lisi', '李李', ['a', 'bbbbb', 'ccccc'], 'zhaoliu', 'lisi']
  ['zhangsna', 'lisi', 'wangwu', ['a', 'bbbbb', 'ccccc'], 'zhaoliu', 'lisi']
 
 要想完整拷贝,需要用到copy模块, copy.deepcopy 深拷贝:
 
  import copy
  names = ["zhangsna","lisi","wangwu",["a","b","c"],"zhaoliu","lisi"]
  names2 = copy.deepcopy(names)
  print(names)
  print(names2)
  names[2]="李李"
  names[3][1]="bbbbb"
  names[3][2]="ccccc"
  print(names)
  print(names2)
 
 输出结果:
  ['zhangsna', 'lisi', 'wangwu', ['a', 'b', 'c'], 'zhaoliu', 'lisi']
  ['zhangsna', 'lisi', 'wangwu', ['a', 'b', 'c'], 'zhaoliu', 'lisi']
  ['zhangsna', 'lisi', '李李', ['a', 'bbbbb', 'ccccc'], 'zhaoliu', 'lisi']
  ['zhangsna', 'lisi', 'wangwu', ['a', 'b', 'c'], 'zhaoliu', 'lisi']
 
 
 列13:列表循序:
  names = ["zhangsna","lisi","wangwu",["a","b","c"],"zhaoliu","lisi"]
  for i in names:
  print(i)
  
  输出:
  zhangsna
  lisi
  wangwu
  ['a', 'b', 'c']
  zhaoliu
  lisi
 
 浅拷贝的4种实现方式:
  person = ["name",['a',100]]
  方式1:
  P1 = copy.copy(person)
  方式2:
  p2 = person[:]
  方式3:
  p2 = person.copy()
  方式4:
  p3 = list(person)
 
  names = ["zhangsna","lisi","wangwu",["a","b","c"],"zhaoliu","lisi"]
  p1 = list(names)
  names[3][1] = 100
  print(p1)
  
  输出:
  ['zhangsna', 'lisi', 'wangwu', ['a', 100, 'c'], 'zhaoliu', 'lisi'] 
 浅拷贝的应用(联合账号): 
  person = ["name",["saving",100]]
  p1 = person.copy()
  p2 = person.copy()
  p1[0] = 'alex'
  p2[0] = 'fengjie'
 
  p1[1][1] = 50
  p2[1][1] = 30
  print(p1)
  print(p2)
 输出结果:
  ['alex', ['saving', 30]]
  ['fengjie', ['saving', 30]]

8. 元组tuple:只读列表,不能增删改;
 
 names = ('alex','jack')
 
 只有2个方法,一个是count,一个是index.
 
  
9. 删除变量:
 del name1
 
10.集合set 用于去重;
 >>> ids = [1,2,3,1,3,1,4,5,1,2,3]
 >>> id = list(set(ids))
 >>> id
 [1, 2, 3, 4, 5]
 >>> print(set(ids))
 {1, 2, 3, 4, 5} 

转载于:https://www.cnblogs.com/brace2011/p/9180466.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
牙科就诊管理系统利用当下成熟完善的SSM框架,使用跨平台的可开发大型商业网站的Java语言,以及最受欢迎的RDBMS应用软件之一的Mysql数据库进行程序开发。实现了用户在线查看数据。管理员管理病例管理、字典管理、公告管理、药单管理、药品管理、药品收藏管理、药品评价管理、药品订单管理、牙医管理、牙医收藏管理、牙医评价管理、牙医挂号管理、用户管理、管理员管理等功能。牙科就诊管理系统的开发根据操作人员需要设计的界面简洁美观,在功能模块布局上跟同类型网站保持一致,程序在实现基本要求功能时,也为数据信息面临的安全问题提供了一些实用的解决方案。可以说该程序在帮助管理者高效率地处理工作事务的同时,也实现了数据信息的整体化,规范化与自动化。 管理员在后台主要管理病例管理、字典管理、公告管理、药单管理、药品管理、药品收藏管理、药品评价管理、药品订单管理、牙医管理、牙医收藏管理、牙医评价管理、牙医挂号管理、用户管理、管理员管理等。 牙医列表页面,此页面提供给管理员的功能有:查看牙医、新增牙医、修改牙医、删除牙医等。公告信息管理页面提供的功能操作有:新增公告,修改公告,删除公告操作。公告类型管理页面显示所有公告类型,在此页面既可以让管理员添加新的公告信息类型,也能对已有的公告类型信息执行编辑更新,失效的公告类型信息也能让管理员快速删除。药品管理页面,此页面提供给管理员的功能有:新增药品,修改药品,删除药品。药品类型管理页面,此页面提供给管理员的功能有:新增药品类型,修改药品类型,删除药品类型。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值