python补充2
一 关于类中的self以及继承问题
请看下面一段代码
class Base:
def f1(self):
self.f2() def f2(self):
print('...') class Foo(Base):
def f2(self):
print('') obj = Foo()
obj.f1() #结果为9999
解说:Foo().f1() -->里面的self指的是实例化的对象,而对象继承的是Foo
实例化类Foo,执行对象的f1方法。由于对象没有f1方法,从父类Base中寻找。
找到f1方法,
def
f1(
self
): 此时
self
指向的是Foo类的对象。执行
self
.f2()
由于
self
是Foo类中的,从Foo类中寻找f2方法。找到了,执行输出
9999
二类的私有属性继承问题
class JustCounter:
__secretCount = 0 def count(self):
self.__secretCount += 1
print(self.__secretCount) class Bars(JustCounter): def count(self):
print(self.__secretCount) counter1 = JustCounter()
counter2 = Bars() counter1.count()
counter2.count() #类的私有属性不会被继承,这里会报错
三递归函数中变量累加覆盖的问题
使用递归函数的时候,需要一个变量一直累加,但是一旦重新递归函数的时候这个变量也会改变,怎么去做
import os
def get_size(path):
ret=os.listdir(path)
# print(ret)
total=0
for name in ret:
# print(name)
abs_path=os.path.join(path,name)
if os.path.isdir(abs_path):
total+=get_size(abs_path) #这里递归的同时total也累加了
else:
total+=os.path.getsize(abs_path)
return total #这里总的大小会稍有变化
print(get_size(r'G:\study\day13'))
四计算目录的大小
上面的例子是一个
下面使用堆栈的概念
import os
def get_size(path):
dir_lst=[path]
total=0
while dir_lst:
path=dir_lst.pop()
ret=os.listdir(path)
for name in ret:
abs_path=os.path.join(path,name)
if os.path.isdir(abs_path):
dir_lst.append(abs_path)
else:
total+=os.path.getsize(abs_path)
return total
print(get_size(r'G:\study\day13'))
找出目录下面的所有文件,并按照从大到小排列
import os
my_list=[]
def get_size(path):
dir_lst=[path]
while dir_lst:
path=dir_lst.pop()
ret=os.listdir(path)
for name in ret:
abs_path=os.path.join(path,name)
if os.path.isdir(abs_path):
dir_lst.append(abs_path)
else:
my_list.append((abs_path,os.path.getsize(abs_path)))
return my_list
aa=get_size(r'G:\study\day22\study-more\version')
# print(aa) bb=sorted(aa,key=lambda x:x[],reverse=True)
print(bb)
五 递归中return的真正理解,跳出函数是跳出最近的函数,以三级菜单举例
menu = {
'北京': {
'海淀': {
'五道口': {
'soho': {},
'网易': {},
'google': {}
},
'中关村': {
'爱奇艺': {},
'汽车之家': {},
'youku': {},
},
'上地': {
'百度': {},
},
},
'昌平': {
'沙河': {
'老男孩': {},
'北航': {},
},
'天通苑': {},
'回龙观': {},
},
'朝阳': {},
'东城': {},
},
'上海': {
'闵行': {
"人民广场": {
'炸鸡店': {}
}
},
'闸北': {
'火车战': {
'携程': {}
}
},
'浦东': {},
},
'山东': {},
}
菜单字典
def menu3(menu):
while True:
for key in menu:
print(key)
inp=input('>>>').strip()
if inp in menu:
ret=menu3(menu[inp]) #递归调用menu3函数,将是一个嵌套
if ret=='q':return 'q'
elif inp=='b':
return 'b' #单纯的返回
elif inp=='q':return 'q' #进入程序单独输入q,直接就是退出menu3函数,这个是没有嵌套的
#进入菜单一直往下走的话,就是使用q在往嵌套函数menu3(menu[inp])的外面跳,直到不嵌套而退出
menu3(menu)
三级菜单函数
三级菜单堆栈实现
l=[menu]
while l:
for key in l[-1]:
print(key)
inp=input('>>>').strip()
if inp in l[-1]:
l.append(l[-1][inp])
print(l)
elif inp=='b':l.pop()
elif inp=='q':break
python补充2的更多相关文章
- Python补充02 Python小技巧
作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 在这里列举一些我使用Python时积累的小技巧.这些技巧是我在使用Python过程 ...
- Python补充06 Python之道
作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! Python有一个彩蛋,用下面语句调出: import this 该彩蛋的文档记录 ...
- python补充最常见的内置函数
最常见的内置函数是: print("Hello World!") 数学运算 abs(-5) # 取绝对值,也就是5 round(2. ...
- Python补充05 字符串格式化 (%操作符)
作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 在许多编程语言中都包含有格式化字符串的功能,比如C和Fortran语言中的格式化输 ...
- Python补充03 Python内置函数清单
作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明. Python内置(built-in)函数随着python解释器的运行而创建.在Pytho ...
- Python补充04 Python简史
原文:Python简史 作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! Python是我喜欢的语言,简洁,优美,容易使用.前两天, ...
- 【Python 补充01】Python运算符
Python运算符 举个简单的例子 4 +5 = 9 . 例子中,4 和 5 被称为操作数,"+" 称为运算符. 1.算术运算符 + - * / # 加减乘除 % # 取模(返回除 ...
- python补充3
一单例模式 类:具体相同特征的一类事物,类似于模板 单例:常用的软件设计模式,用于设计一个类中只有一个实例且易于外界访问,可以对实例的个数控制并节约系统资源 运用场景:比如某个服务器程序的配置信息,它 ...
- python补充知识点
1. 在python2中用xrange,在python3中直接使用range就好了 2. 常数 None在逻辑判断的时候指代False,其他方式不代表True或者False 3. for循环只作用域容 ...
- python 补充:join() , 基本数据类型的增删改查以及深浅拷贝
# join() join() 方法用于将序列中的元素以指定的字符连接生成一个新的字符串. li = ["李李嘉诚", "麻花藤", "黄海海峰&q ...
随机推荐
- I.MX6 OTG set as slave device hacking
/****************************************************************************** * IMX6 OTG set as sl ...
- win10笔记本实现双屏显示的自如切换
前言 使用电脑的过程中想一边看内容,一边进行编辑,这就涉及到双屏显示并实现扩展分屏,本文就介绍一下这些操作. 工具 win10-thinkpad-E470:另一块显示屏(博主的是戴尔的显示器):一条外 ...
- [LeetCode&Python] Problem 476. Number Complement
Given a positive integer, output its complement number. The complement strategy is to flip the bits ...
- Avito Cool Challenge 2018(div1+2)
A. Definite Game: 题意:输入N,输出最小的结果N-x,其中x不少N的因子. 思路:N=2时,输出2:其他情况输出1:因为N>2时,N-1不会是N的因子. #include< ...
- Xcode7( linker command failed with exit code 1)
”Build Settings”->”Enable Bitcode”设置为NO ,因为有些SDK不支持Bitcode
- 实验吧—密码学——WP之 传统知识+古典密码
仔细读题,发现有价值的信息: 几个不同的年份:“+甲子”:key值结构 首先我们并不知道这些年份在这里代表着什么,那么我们就去百度一下发现了如下所示的六十甲子顺序表 而在表中每个年份前都有数字,将他们 ...
- 差分约束+spfa【模板】
相比dij,spfa优点是可处理含负边不含负圈的最短路问题,缺点是算法复杂度不太好[貌似可以使用两种优化.LLL和SLF] 差分约束就是将一些不等式转化为图中的带权边,然后求解最短路或最长路的方法 洛 ...
- leetcode:Longest Common Prefix【Python版】
1.当strs为空,直接输出“” 2.当strs中含有“”,直接输出“” 3.strs[0]的最长长度由最短公共长度l决定(code line:15) class Solution: # @retur ...
- yugabyte 集成JanusGraph测试
yugabyte 集成图数据库JanusGraph,原理比较简单就是yugabyte 内置Cassandra,配置好JanusGraph 的访问就可以了. 使用docker 模式部署 创建yugaby ...
- web.xml中context-param详解
<context-param> <param-name>contextConfigLocation</param-name> <param-value> ...