学习内容:
1、Python字典
2、Python集合
3、Python字符编码
4、Python文件操作
5、Python实例
一、Python字典
1、定义:
dic1={'name':'alex','age':18,}
字典的Key值定义规则:
1)数据类型不可变,数据类型可哈希的就可以是key
2)字典的Key值是唯一的
2、查询
dic1['name'] 若Key值不存在,会报错
dic1.get(123456) 若Key值不存在,返回None
3、增加
dic1['sex'] = 'F'
4、更改
dic1['sex'] = 'M'
5、删除
del dic1['sex']
6、字典的内置函数
dic1.clear() #清空字典
dic1=names.copy() #复制
dic2=dic1.fromkeys('abc',1) #重新定义一个字典,结果与dic1无关
dic1.get('name') 等同于dic1['name'] 若Key值不存在,前者不报错,后者会报错
dic1.items() #将key、value转成元组保存在列表中
dic1.pop('key值') #删除字典中的key值,打印返回value
dic1.popitem() #随机删除 若key值为空,出现KeyError错误
dic1.setdefault('gender',[]) #新增字典内容==dic1['gender']
dic1.setdefault('gender',[]).append('male')
names.update(dic1) # names新增dic1内容,重复的覆盖
dic1.update(name='lhf',gender='nale') #将内容新增到字典中,key值重复的覆盖掉
dic1.values() #取所有value值保存在列表中
dic1.keys() #取所有key值保存在列表中
import copy
copy.copy() #浅copy
copy.deepcopy() #深copy 完全克隆一份
二、Python集合
1、创建
s1={'a',1,2,3,4,5,6,7,8,9,10,2,3,3}
list_1 = [1,3,5,7,26,8,65]
list_1=set(list_1)
python_set={'alex','lhf','sijiayong','panmfeng','sunahaifeng'}
linux_set={'zhao','qian','alex','lhf'}
go_set={'alex','linyi','qiner'}
print (type(python_set))
2、集合间的操作
1)交集 & or intersection
python_set.intersection(linux_set)
2)并集 | or union
python_set.union(linux_set)
3)差集 - or difference
python_set.difference(linux_set)
4)对称差集 ^ or symmetric_difference
python_set.symmetric_difference(linux_set)
5)子集 <= or issubset
s1.issubset(s2)
6)父集 >= or issuperset
s1.issuperset(s2)
3、集合的内置函数
s1.update('eh') #按单个增加
s1.add('hello') #按一个字符串增加
s1.pop() #随机删除
s1.remove('Y') #指定删除,若没有该元素,则报
s1.discard('o') #不报错的删除,若没有该元素,返回None
三、Python字符编码
1、内存固定使用unicode编码,硬盘的编码(即你可以修改的软件编码)
2、使用什么编码往硬盘存,就用什么编码去读取
3、程序运行分俩个阶段:1)从硬盘读到内存;2)python解释器运行已经读到内存的代码
4、针对一个test.py文件来说,python与pycharm、nodpad++的区别是多了第二步骤
5、coding指定的编码只是表面从硬盘到内存用什么区读
四、Python文件操作
1、打开文件
指定用utf-8编码打开文件,默认是读模式(r)
f=open ('lyrics',encoding='utf-8')
2、读取文件
f.readline().strip()
3、写文件
f=open ('lyrics','w',encoding='utf-8')
f.write('*上太阳升\n')
4、遍历文件
第一种方法(一行一行读取,高效):
for line in f :
print (line.strip())
f.close()
第二种方法(也是一行一行读取):
for i in range(5):
print (f.readline().strip())
第三种方法(把文件全部读取到内存中,建议不要用):
for index,line in enumerate(f.readlines()):
if index <5:
print (line.strip())
else:
break
5、文件的混合模式
r+ 读写
w+ 写读
a+ 追加读
6、文件的内置函数
print(f.closed) #关闭打开的文件
print (f.encoding) #文件编码
print (f.fileno()) #文件时系统帮忙打开的,返回的是系统内该文件的文件标签
f.flush() #将缓冲区的内容写入硬盘
f.isatty() #判断是否为tty终端文件
print(f.name) #打印f文件的名字
f.seek() #移动光标
f.seekable() #二进制文件不可以seek
f.tell() #告诉当前光标的位置
f.truncate( ) #截断,从光标的位置把内容全截断,对于文本的截断没大用,只能按字符截断,对二进制文件有用
7、文件的内容修改
f = open('lyrics','r',encoding='utf-8')
f2 = open('lyrics_new','w',encoding='utf-8')
find_str = '夜晚的'
new_str = '白天的寒冷的'
for line in f:
if find_str in line:
line =line.replace(find_str,new_str)
f2.write(line)
f.close()
f2.close()
五、Python实例
1、sed替换程序
2、修改haproxy配置文件程序