1.字典
字典的创建:
dict1=dict((('name','PIG'),)),其中第一层()代表里面的内容是dict函数的输入参数。
第二层和第三层代表字典中的各元素,也就是key和value组合的列表,只不过这种列表不
是一种线性列表list,而是hash列表。在dict()和list()的函数调用中,里面用list标识符[]或者()
元组tuple效果一样。也可以像int()一样,将其看成强转换。
dict2={'name':'PIG'}
字典的修改:
dict1={'name':'dog'}
dict1['age']=18
dict1.setdefault('name','cat')
dict1.setdefault('age',34)
这两种效果一致
字典的查找:
dict2={'age': 23, 'name': 'pis','career': 'student'}
print(dict2['name'])
print(list(dict2.keys()))
print(list(dict2.values()))
print(list(dict2.items()))
print出来的顺序与输入无关,而是根据hash算法自动调整。list()是一个强制类型转换。
将keys/values/items类型转换为list类型。
dict3={'age': 23, 'name': 'pis','career': 'student'}
dict4={'birthday':'94-09-01'}
dict3.update(dic4)
print(dict3)
updata()将key值相同的替换,其他的添加。
key值只能为数值,tuple,字符串等不可变类型,不能为list和dict。
删除元素
dict4.clear() # 清空字典
print(dict4)
del dict4['name'] #删除字典中指定键值对
print(dict4)
print(dict4.pop('age')) #删除字典中指定键值对,并返回该键值对的值
ret=dict4.pop('age')
print(ret)
print(dict4)
pop操作可返回被pop的value值。
a = dict4.popitem() #随机删除某组键值对,并以元组方式返回值
print(a, dict4)
del dict4 #删除整个字典
print(dict4)
其他操作以及涉及到的方法
dict5=dict.fromkeys(['host1','host2','host3'],'test')
dict6=dict.fromkeys(['host1','host2','host3'],['test1','tets2'])
#print(dic6)
#dic6['host2']='abc'
#print(dic6)
这两个的区别是改变某一个key值时,第一个不影响其他的,第二个一起改变。因为字符串是不可变类型,list
是可变类型。
dict可嵌套dict。
sorted(dict6.items())可对无序的hash顺序按照key值排序。
对dict和list的for运算
for i in dic5:
print(i,dic5[i])
for i,v in dic5.items():
print(i,v)
2 string操作
a='dad'
b='mom'
c=a+b 加操作
d=a*5 乘操作
print('helloworld'[2:])切片操作
关键字 in
# print(123 in [23,45,123])
# print('e2l' in 'hello')输出True和False
格式化输出
print('%s is a good teacher'%'alex')
msg='''
----------info of %s----------
Name: %s
Age : %d
Job : %s
Salary: %f
You will be retired in %s years
----------end---------
''' % (name, name, age, job, salary, 50-age)
c=# print(c)连接join方法
''.join([a,b,d])
#摘一些重要的字符串方法
#1 print(st.count('l'))
# print(st.center(50,'#')) # 居中
# print(st.startswith('he')) # 判断是否以某个内容开头
# print(st.find('t'))
# print(st.format(name='alex',age=37)) # 格式化输出的另一种方式 待定:?:{}
# print('My tLtle'.lower())
# print('My tLtle'.upper())
# print('\tMy tLtle\n'.strip())
# print('My title title'.replace('itle','lesson',1))
# print('My title title'.split('i',1))
具体可看string类源码
3.list操作
list的切片操作
#a=['xiaohong', 'xiaoming', 'xiaoliang', 'xiaofang', 'xiaoli']
# print(a[2:-1])
# print(a[1:])
# print(a[1:-1])
# print(a[1:-1:1])
# print(a[1::2])
# print(a[3::-2])
增
# a.append('xiaoliu')
# print(a)
# a.insert(1,'xiaoxiong')
# print(a)
改
a[1] = 'haidilao'
# print(a)
# a[1:3] = ['da','ads']
# print(a)
删
# a.remove('xiaoming')
# print(a)
# b = a.pop(1)
#
# print(a)
# print(b)
# del(a[0])
# print(a)
# del(a)
# print(a)
# a.pop(1)
# print(a)
其他操作
#t = ['to', 'on', 'be', 'to', 'to', 'to'].count('to')
# print(t)
#
# a = [1, 2, 3]
# b = [4, 5, 6]
# a.extend(b)
# print(a)
# print(b)
# print(a.index(1))
# a.reverse()
# print(a)
# x = [4, 6, 2, 1, 7, 9, ]
# x.sort()
# print(x)
#t = ['to', 'on', 'be', 'to', 'to', 'to']
# t.sort(reverse=True)
# print(t)
# print(t.count('dad'))
# print("haide"in t)
# b = t.copy()
# print(b)
主要关注三种重要的数据类型list tuple dictionary的常用操作