设为首页 收藏本站
查看: 1036|回复: 0

[经验分享] CrazyWing:Python自动化运维开发实战 九、Python数据类型之列表

[复制链接]

尚未签到

发表于 2018-8-4 09:44:11 | 显示全部楼层 |阅读模式
导语
  序列:
  序列是Python中最基本的数据结构。序列中的每个元素都分配一个数字 - 它的位置,或索引,第一个索引是0,第二个索引是1,依此类推,Python已经内置确定序列的长度以及确定最大和最小的元素的方法。Python有6个序列的内置类型,最常见的是列表和元组。
  序列操作包括:
  索引,切片,加,乘,检查成员

列表:
  

列表是序列的一种,属最常用的Python数据类型,它支持字符,数字,字符串甚至可以包含列表(嵌套),他的数据项不需要具有相同的类型  

创建列表:
  以逗号分隔的不同的数据项使用方括号括起来即可。
  例如:
  

list1 = ['physics', 'chemistry', 1997, 2000];  
list2 = [1, 2, 3, 4, 5 ];
  
list3 = ["a", "b", "c", "d"];
  
list4 = []       #创建空列表
  
list5 = list()  #创建空列表
  

列表截取:
  语法:变量[头下标:尾下标]
  从左到右索引默认0开始的,从右到左索引默认-1开始,下标可以为空,表示取到头或尾。
  跟字符串的截取一样,这里不再详述
  例1:
  #!/usr/bin/python
  list1 = ['physics', 'chemistry', 1997, 2000];
  list2 = [1, 2, 3, 4, 5, 6, 7 ];
  

print "list1[0]: ", list1[0]  
print "list2[1:5]: ", list2[1:5]
  

  
以上实例输出结果:
  
list1[0]:  physics
  
list2[1:5]:  [2, 3, 4, 5]
  

  例2:
  

L = ['spam', 'Spam', 'SPAM!']  

  
| L[2] | 'SPAM!' | 读取列表中第三个元素 |
  
| L[-2] | 'Spam' | 读取列表中倒数第二个元素 |
  
| L[1:] | ['Spam', 'SPAM!'] | 从第二个元素开始截取列表 |
  

更新列表:
  

可以对列表的数据项进行修改或更新,也可以使用append()方法来添加列表项  
例如:
  
#!/usr/bin/python
  
list = ['physics', 'chemistry', 1997, 2000];
  
print "Value available at index 2 : "
  
print list[2]
  
list[2] = 2001    #更新列表元素
  
print "New value available at index 2 : "
  
print list[2]
  

  
以上实例输出结果:
  
Value available at index 2 :
  
1997
  
New value available at index 2 :
  
2001
  

删除列表元素:
  

使用 del 语句来删除列表的的元素  
例:
  
#!/usr/bin/python
  
list1 = ['physics', 'chemistry', 1997, 2000]
  
print list1
  
del list1[2]
  
print "After deleting value at index 2 : "
  
print list1
  

  
以上实例输出结果:
  
['physics', 'chemistry', 1997, 2000]
  
After deleting value at index 2 :
  
['physics', 'chemistry', 2000]
  

Python列表操作符:
  

+ 号用于组合列表  
* 号用于重复列表
  
in 判断元素是否在列表中
  
not in
  
例:
  

| Python 表达式 | 结果  |  描述 |  
| [1, 2, 3] + [4, 5, 6] | [1, 2, 3, 4, 5, 6] | 组合 |
  
| ['Hi!'] * 4 | ['Hi!', 'Hi!', 'Hi!', 'Hi!'] | 重复 |
  
| 3 in [1, 2, 3] | True | 元素是否存在于列表中 |
  
| for x in [1, 2, 3]: print x, | 1 2 3 | 迭代 |
  

Python列表函数:
  

| 序号 | 函数 |  
| 1 | cmp(list1, list2)    比较两个列表的元素 |
  
| 2 | len(list)                 列表元素个数 |
  
| 3 | max(list)               返回列表元素最大值 |
  
| 4 | min(list)                返回列表元素最小值 |
  
| 5 | list(seq)                将序列转换为列表 |
  

Python列表方法:
  

| 序号 |                                方法                       |  
| 1 |  list.append(obj) 在列表末尾添加新的对象 |
  
| 2 |  list.count(obj)     统计某个元素在列表中出现的次数 |
  
| 3 |  list.extend(seq)  在列表末尾一次性追加另一个序列中的多个值(用新列表扩展原来的列表) |
  
| 4 |  list.index(obj)     从列表中找出某个值第一个匹配项的索引位置 |
  
| 5 |  list.insert(index, obj) 将对象插入列表 |
  
| 6 |  list.pop(obj=list[-1]) 移除列表中的一个元素(默认最后一个元素),并且返回该元素的值 |
  
| 7 |  list.remove(obj)   移除列表中某个值的第一个匹配项 |
  
| 8 |  list.reverse()        反向列表中元素 |
  
| 9 |  list.sort([func])     对原列表进行排序 |
  

  给列表插入数据的其他方法:
  

In [1]: a=[12,3,4,3]  
In [2]: a[2:2]=[8,8]
  
In [3]: a
  
Out[3]: [12, 3, 8, 8, 4, 3]
  

  批量替换:
  

In [4]: a=[12, 3, 8, 8, 4, 3]  
In [5]: a[2:]=[1,1,1,]
  
In [6]: a
  
Out[6]: [12, 3, 1, 1, 1]
  

  另类删除:
  

In [7]: a=[12,3,4,3]  
In [8]: a[2:]=[]
  
In [9]: a
  
Out[9]: [12, 3]
  

  列表中嵌套列表:
  

>>> a=[1,2,['a','b']]  
>>> a
  
[1, 2, ['a', 'b']]
  
>>> a[2]
  
['a', 'b']
  
>>> a[2][0]
  
'a'
  
>>> a[2][1]
  
'b'
  

  判断一个对象是否是一个列表:

  >> test=[1,2,3]
  >> isinstance(test,list)
  True

  列表变量解包:

  >> l1,l2 = [[1,'x','y'],[2,'z','r']]
  >> print(l1)
  [1, 'x', 'y']
  >> print(l2)
  [2, 'z', 'r']

  查看系统内所有内置函数(BIF):isinstance就在里面

  >> dir(builtins)

祛除列表中重复的元素
  比较容易记忆的是用内置的set:
  

l1 = ['b','c','d','b','c','a','a']  
l2 = list(set(l1))
  
print l2
  

  还有一种据说速度更快的,没测试过两者的速度差别
  

l1 = ['b','c','d','b','c','a','a']  
l2 = {}.fromkeys(l1).keys()
  
print l2
  

  这两种都有个缺点,祛除重复元素后排序变了:
  

['a', 'c', 'b', 'd']  

  如果想要保持他们原来的排序:
  

用list类的sort方法  l1 = ['b','c','d','b','c','a','a']
  l2 = list(set(l1))
  l2.sort(key=l1.index)
  print l2
  

  
也可以这样写:
  l1 = ['b','c','d','b','c','a','a']
  l2 = sorted(set(l1),key=l1.index)
  print l2
  

  
也可以用遍历:
  l1 = ['b','c','d','b','c','a','a']
  l2 = []
  for i in l1:
  if not i in l2:
  l2.append(i)
  print l2
  

  
上面的代码也可以这样写
  l1 = ['b','c','d','b','c','a','a']
  l2 = []
  [l2.append(i) for i in l1 if not i in l2]
  print l2
  

  
这样就可以保证排序不变了:
  ['b', 'c', 'd', 'a']

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-546297-1-1.html 上篇帖子: python教程,python入门教程 下篇帖子: python—多进程的消息队列
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表