Python学习的第三次的总结
2021-04-14 06:27
标签:移动 循环 ext 三级菜单 write 时间 rar 字节 inpu 元组 #组内元素可读,不能被改变 tup1=() #空元组 tup2=(1,) #一个元素后添加逗号 嵌套列表 a = [[1,2,3],‘lyyyyy‘,4,(2,3,4)] b = a[0] b[0] = 1 → a[0][0] = 1 小技巧 1、if s.isdigit():s = int(s) #判断为数字后,转换类型 2、for i in list: print(list.index(i),i) #打印list中的索引值和对应的内容 3、for i,v in enumerate(列表,从第几个序列开始): print(i,v) #打印出需要的序列和对应的内容 4、len(s) #判断字符串的长短 5、print (‘I am %s‘%(变量名)) #使用占位符打印一行 6 、s.pop() #默认返回最后一个值,通常用来计数列表个数 7、[ ] 空列表可以充当购物车 id() #用来找地址 8、 for i in range(0,len(a)): #购买相同的物品数量输出 c=products_cart.count(a[i][0]) #遍历列表,计数 if c>=1: print(a[i][0],"*",c,end=",") Ø购物车的实现 字典(唯一映射关系) 特点:1、无序储存 2、key必须是可哈希的(不可修改,唯一) 不可变类型:整形、字符串、元组 可变类型:列表、字典 操作方法: 1、增加 dic1 = {‘name‘:‘lyyy‘} dic1 = [‘age‘] = 18 ret = dic1.setdefault(‘age‘,34) 结果:ret = {‘name‘:‘lyyy‘ , ‘age‘:18} #如果原有相同的key则不变更原有的值,反之则添加新的键值对 2、查找 dic1 = {‘name‘:‘lyyy‘} print(dic1[‘name‘]) #通过key去查找 print(list(dic1.keys())) #查找所有的key,并以列表的形式展现 print(list(dic1.values())) #查找所有的值,并以列表的形式展现 print(list(dic1.items())) #查找所有的键值对,并以列表的形式展现 3、改 dic1 = {‘name‘:‘lyyy‘,‘height‘:168} dic1 [‘name‘]= ‘yzqqqq‘ #取出来赋新值 dic1 = {‘name‘:‘lyyy‘,‘height‘:168} dic2 = {‘name‘:‘yzzzzzq‘,‘gender‘:‘male‘} dic1.update(dic2) print(dic1) 结果:{‘name‘: ‘yzzzzzq‘, ‘height‘: 168, ‘gender‘: ‘male‘} #若用来添加的key和原有的key一样,则更新新值;若无相同的key,则补充进去 4、删除 dic1 = {‘name‘:‘lyyy‘,‘height‘:168} del dic1[‘name‘] #删除该项 del dic1 #从内存中删除 dic1.clear() #清空 dic1.pop() #删除并返回相应值 a = dic1.popitem() print(a,dic1) #随机删除,并以元组的方式返回 5、其他 初始化 dic1 = dict.fromkeys([‘host1‘,‘host2‘],‘test‘) print(dic1) 结果:{‘host1‘: ‘test‘, ‘host2‘: ‘test‘} 6、字典嵌套 7、排序 dic={5:‘111‘,2:‘666‘,4:‘444‘} sorted(dic.items()) 8、字典遍历 dic = {‘name‘: ‘yzzzzzq‘, ‘height‘: 168, ‘gender‘: ‘male‘} 方法一:for i in dic: print(i,dic[i]) #打印键值对 方法二:for i,v in dic.items(): print(i,v) #item里有两个参数,分别取出 ◊ 三级菜单的实现(可以一层层进入和返回) 字符串的操作 1、print(‘123446‘*2) #重复打印 2、print(‘1231785‘, [2: ]) #切片 3、print(‘123‘ in ‘12345‘) True #关键字in 4、‘ 连接物 ‘ . join([a,b]) # 以连接物把 a,b 连接起来;若无连接物,则为紧贴链接 5、string.count() #计数 6、string.capitalize() #首字母大写 7、string.center(50,‘-‘) ----------string----------- #以特殊字符居中 8、string.endswith(‘edbyy‘) #以某个字符串结尾 9、string.startswith(‘bxtqiu‘) # 以某个内容开头 10、string.expandtabs(tabsize = 10) # 把tab ‘\t‘ 转成空格 11、string.find(‘t‘) #查找某个字符串中的元素,并返回其索引值 12、string = ‘Hello {name}‘ string.format_map( { ‘name‘ : ‘ly‘ } ) 结果:Hello ly #格式化输出,采用字典 13、string.isalnum() #包含数字和字母则返回True 14、string.iscecmal() #判断是否是十进制的数值 15、string.isdigit() #判断是否为数字 16、string.isalpha() #判断是否为字母 17、string.isidentifier() #检验变量名是否合法 18、string.islower() #判断是否全为小写 19、string.isupper() #判断是否全为大写 20、string.isspace() #判断是否为空格 21、string,istiltle() #判断是否为标题(首字母大写) 22、string.lower() #全变为小写 23、string.upper() #全变为大写 24、string.swapcase() #大写变为小写,小写变大写 25、string.ljust(50,‘ - ‘) #居左 26、string.rjust(50,‘ - ‘) #居左 27、string.strip() #去掉字符串左右的空格,换行符 28、string.replace(‘去掉的内容‘,‘替代的内容‘,替换的次数) #替代 29、string.split(‘ 以字符串中的某个元素进行分割 ‘,分割次数) #分割,分割符消失 导入系统时间 import datetime time = datetime.datetime.now().data() 例:2020-7-12 字符编码 1、二进制 → ASCII(py2) → gbk2312 → gbk10 → gb18030 → unicode(utf-32 4个字节 utf-16 2/2个以上字节 utf-8 中文3个字节,英文用ASCII存)(py3) 2、GBK ← 解码 Unicode ← 编码 JPK 3、encode在编码的同时,会把数据转成bytes字节类型;decode在解码同时,把字节转成字符串 文件操作(能调用方法的一定是对象) 1、f = open(‘文件名‘, ‘r‘ ) #打开文件 2、f = open(‘文件名‘, ‘a‘ ) #尾部追加,不清空原有的内容 3、data = f.read(5) #默认全取,或取几个字符 4、f = open(‘文件名‘, ‘w‘ ) #可读模式,清空原有文件的内容,或创建新的文件 f.write(‘hello lyyy‘) #清空再写 5、f.close() #一定要关闭文件,这样内容才会被刻进硬盘里 6、f.fileno() #返回特殊的非0整形 7、import time time.sleep(50) #程序运行50秒 8、f.readline() #打印第一行内容,重复则接着打印下一行,光标会跟着移动 9、f.readlines() #由每一行字符串组成的列表 for i in f.readlines() print( i.strip()) #去掉print带来的自动换行 10、for i in f : print(i) #通常打开文件用这个办法,储存在迭代器里,不存在内存里,需要用的时候再取出来 11、f.tell() #默认光标的位置在初始,实时定位光标的位置(英文字符占1个位置,中文3个) 12、f.seek(0) #调整光标的位置到某个地方 13、f.flush() #把缓存的数据实时转到硬盘上 14、f.truncate(5) #把光标移动到第五个位置,顺便把后面的全删了 15、f.isatty() #确定是否为终端 16、f = open(‘文件名‘,‘r+‘) #读写模式,光标在起始位置 17、f = open(‘文件名‘,‘w+‘) #写读模式,清空原有的内容再写 18、f = open(‘文件名‘,‘a+‘) #读写模式,光标在末端位置 (呜呜呜呜呜呜,好痛苦的一次总结!太多了!这就是懒惰的恶果!!!!!下次再也不这样了!!) Python学习的第三次的总结 标签:移动 循环 ext 三级菜单 write 时间 rar 字节 inpu 原文地址:https://www.cnblogs.com/linyu3454/p/13335203.html
guangdong_province={
‘广州市‘:{
‘天河区‘:{‘华农‘,‘华师‘,‘华工‘},
‘海珠区‘:{‘广州塔‘,‘大剧院‘,‘广图‘},
‘番禺区‘:{‘大学城‘,‘广州南站‘,‘美食街‘}
},
‘东莞市‘:{
‘塘厦镇‘:{‘yzqDD家‘,‘yzq打球场‘,‘yzq剪头发地‘},
‘虎门镇‘:{‘威远炮台‘,‘好吃的‘,‘食品学院plxjj的家‘}
},
‘湛江市‘:{
‘霞山区‘:{‘ly靓女家‘,‘鼎盛广场‘,‘海滨公园‘},
‘赤坎区‘:{‘金沙湾‘,‘一中‘,‘湛江博物馆‘},
‘开发区‘:{‘二中‘,‘海关‘,‘海湾大桥‘}
}
}
sorted(dic.keys()) menu = {
‘广东省‘:{
‘广州市‘:{
‘天河区‘:{‘华农‘,‘华师‘,‘华工‘},
‘海珠区‘:{‘广州塔‘,‘大剧院‘,‘广图‘},
‘番禺区‘:{‘大学城‘,‘广州南站‘,‘美食街‘}
},
‘东莞市‘:{
‘塘厦镇‘:{‘yzqDD家‘,‘yzq打球场‘,‘yzq剪头发地‘},
‘虎门镇‘:{‘威远炮台‘,‘好吃的‘,‘食品学院plxjj的家‘}
},
‘湛江市‘:{
‘霞山区‘:{‘ly靓女家‘,‘鼎盛广场‘,‘海滨公园‘},
‘赤坎区‘:{‘金沙湾‘,‘一中‘,‘湛江博物馆‘},
‘开发区‘:{‘二中‘,‘海关‘,‘海湾大桥‘}
}
},
‘广西省‘:{
‘南宁市‘:{
‘清秀区‘:{‘清‘,‘秀‘},
‘江南区‘:{‘江‘,‘南‘}
},
‘柳州市‘:{
‘柳城‘:{‘螺蛳粉‘,‘好吃的‘},
‘龙城‘:{‘龙‘,‘城‘}
}
}
}
current_layer = menu
father_layer = [] #父集
while True:
for key in current_layer:
print(key) #打印current_layer的key #唯一的输出
choice = input(‘请输入要查询的地区:‘).strip()
if len(choice) == 0:
continue
if choice in current_layer:
father_layer.append(current_layer) #记下父级
current_layer = current_layer[choice] #更替子级
elif choice == ‘back‘:
if father_layer: #非空即为真,则执行
current_layer = father_layer.pop() #将下一次循环要打印key的current_layer更替成父集的删除返回值
#并且取最后一个值
#pop()通常用来取最后一个值
else:
print(‘查无此地‘) #不管那一层循环输入错误都会提示
下一篇:js数组去重几种方法