python学习道路(day3note)(元组,字典 ,集合,字符编码,文件操作)

时间:2021-11-23 09:31:49
1.元组()
元组跟列表一样,但是不能增删改,能查。元组又叫只读列表
2个方法 一个 count 一个 index

2.字典{}
字典是通过key来寻找value
因为这里功能比较多,所以写入了一个Code里面,后面加了注释。
 #!/usr/bin/env python
 #_*_coding:utf-8_*_

 info = {
     'stu1101':"Tenglan Wu",
     'stu1102':"LongZe Luola",
     'stu1103':"XiaoZe Maliya",
 }
 #print(info)
 #print(info["stu1101"]) #查找
 #print(info.get('stu1104')) #查找  常用
 #info['stu1101'] = "武藤兰"  #修改
 #info['stu1104'] = "cangjingkong" #添加
 #del
 #del info["stu1101"] #删除
 #info.pop("stu1101") #删除
 #print("stu1103" in info)  #判读是不是有个这个key,返回true false
 # #print(info)
 b = {
     'stu1101':"alex",
     1:3,
     2:5,
 }
 #info.update(b)    #把2个字典合并,有交叉的Key覆盖,没有的旧添加
 #print(info)
 #c = dict.fromkeys([6,7,8],[1,{"name":"alex"},444]) 没用
 #print(c)
 #print(info.items()) #把字典转化为一个列表

 for i in info:
     print(i,info[i])   #这个更高效
 for k,v in info.items(): #items 是把字典转为列表过程,时间会慢
     print(k,v)

3.集合

跟数学里面的定义差不多

因为这里功能比较多,所以写入了一个Code里面,后面加了注释。

 #!/usr/bin/env python
 #_*_coding:utf-8_*_

 #集合
 #list_1 = [1,4,5,7,3,6,7,9]  #集合也是无序的
 #list_1 = set(list_1)   #list_1化为集合
 #print(list_1,type(list_1))
 #list_2 = set([2,6,0,66,22,8,4])
 #print(list_1,list_2)

 #交集  &
 #print(list_1.intersection(list_2))
 #并集  |
 #print(list_1.union(list_2))#union联合的意思
 #差级 我有你没有,你有我没有的  -
 #print(list_1.difference(list_2))  #保留1里面有的,2里面有没有的
 #子集  我包含你
 #print(list_1.issubset(list_2)) #返回ture false
 #print(list_1.issuperset(list_2))
 #对称差集  ^ 上面的
 #print(list_1.symmetric_difference(list_2))#互相都没有的取出来放到一块
 #print(list_1.isdisjoint(list_2)) #判断有没有交集 返回true false

 #添加一项
 #list_1.add(999)
 #print(list_1)
 #添加多个
 #list_1.update([888,777,555])
 #print(list_1)
 #删除
 #list_1.remove(888) #不用print删除就是删除了
 #list_1.pop()
 #list_1.discard(777)  #删除不会报错
 #长度
 #print(len(list_1))
 #成员使用
 #in not in

4.字符编码

记住一句话,用什么编码写的程序,就用什么编码打开  

 #!/usr/bin/env python
 #_*_coding:utf-8_*_

 #默认编码
 #import sys
 #print(sys.getfilesystemencoding())
 #s = "您好"
 #s_to_unicode = s.decode("utf-8")
 #print(s_to_unicode)
 #s_to_gbk = s.decode("utf-8").encode("gbk")  #(不给值,就是默认)
 #print(s_to_gbk)

5.文件操作

一般r+ w的关闭和打开具有清空文件作用

因为这里功能比较多,所以写入了一个Code里面,后面加了注释。

 #!/usr/bin/env python
 #_*_coding:utf-8_*_

 #文件操作
 #readlines 是将文件读成列表的形式 ,每行就是一个元素  预先读到内存里成列表
 #date = open("yesterday.txt",encoding="utf-8").read()
 #f = open("yesterday.txt",'w',encoding="utf-8")#f 文件句柄,就是这个文件的内存文件对象 w这个写模式是创建文件会覆盖
 #date= f.read()
 #f = open("yesterday.txt",'a',encoding="utf-8") #a 就是追加不覆盖文件
 #ate2 =f.read()#文件指针的这种东西,date2没有内容,文件只读一遍
 #print(date)
 #f.write("我爱北京*.......,\n") #斜杠为转义符,\n就是回车
 #f.write("*上太阳升......")
 #读前五行
 #f = open("yesterday.txt",'r',encoding="utf-8")
 #print(f.readline())
 #print(f.readline())
 #print(f.readline())
 #for i in range(5):
 #    print(f.readline())
 #for line in f.readlines():  #循环列表,相当于每一行,每一行元素
 #    print(line.strip())
 #print(f.readlines())    #每行一个元素

 #for index,line in enumerate(f.readlines()):   #打印到9行前内容 但是提前读了全文 f.readline适合小文件
 #    if index == 9:
 #        print("___fengexian____")
 #        continue
 #    print(line.strip())

 #count = 0
 #for line in f:   #一行行的读,内存也只读一行信息#打印到9行前内容
 #    if count == 9:
 #         print("fdsfsdfsdfsdf___fengexian____dsfdfdsfdsfs")
 #         count += 1
 #         continue
 #    print(line)
 #    count += 1

 #print(f.read(5))#读五个字符
 #print(f.tell())#告诉你文件句柄的指针打印出来 按字符个数计数
 #f.seek(0)#回到光标的开始位置  0可以是其他前面的会被删除显示
 #print(f.readline())
 #print(f.encoding)#打印文件编码
 #print(f.fileno()) #返回一个编号,一个接口,调用操作系统文件的IO
 #print(f.name)#打印文件名字
 #print(f.isatty())#终端 tty
 #print(f.readable())#判断文件是否可读
 #print(f.writable())#判断文件是否可写
 #print(f.flush())#刷为了解决文件存在内存然后恶意关闭,其实他是有个内存值,当达到了这个值会直接写到硬盘里面
 #f = open("yesterday.txt",'a',encoding="utf-8")

 #print(f.closed) #判断文件是否关闭
 #f.truncate(10)#本意截断的意思 不写就是清空 从10往后截断 还需要跟a配合
 #f.close()

 #文件读写
 #f = open("yesterday.txt",'r+',encoding="utf-8") #以读和追加打开  a+追加读
 ##print(f.readline())
 #print(f.tell())
 #f.write("12456----duiaoi-------")
 #写读
 #f = open("yesterday.txt",'w+',encoding="utf-8") #先创建个文件再追加进去 rb读二进制文件 显示b'就是bytes文件
 #多用于网络传输,进制文件
 #f.write("12456----duiaoi-------")
 #print(f.tell())
 #f.seek(10)
 #print(f.tell())
 #print(f.readline())
 #f.write("wode tian a shenme iqnkguang ")
 #在原文件上的修改必须同字符,不然不能修改会把内容覆盖
 #ru r+u windows上\r回车,linux\n回车为了统一

 #硬盘修改文件方法
 #f = open("yesterday.txt",'r',encoding="utf-8")
 #f_new = open("yesterday.bak.txt",'w',encoding="utf-8")
 #for line in f:
 #    if "年少轻狂" in line:
 #        line = line.replace("年少轻狂","hahaha")
 #    f_new.write(line)
 #f.close()
 #f_new.close()

 #with 语法 可以不需要手动写关闭
 #with open("yesterday.txt",'r',encoding="utf-8") as f:
 #    for line in f:
 #        print(line.strip())
 #同时打开2个文件
 #with open("yesterday.txt",'r',encoding="utf-8") as f,\
 #      open("yesterday.bak.txt",'w',encoding="utf-8") as f_new: