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: