# __class__表示当前操作的对象是什么 # 1、如何让b的对象实现a的shou方法 # class A: # def show(self): # print("A-show") # # class B(A): # def show(self): # print("B-show") # # # obj = B() # # # print(obj.__class__) # # obj.__class__=A # # obj.show() # 2、这段代码怎么才能运行,(为了让对象的实例可以被直接调用,实现call方法) # class A(object): # def __init__(self,a,b): # self.__a = a # self.__b = b # def myprint(self): # print("a=",self.__a,"b=",self.__b) # # def __call__(self, num): # # print("call:",num + self.__a) # # # a = A(10,20) # # a.myprint() # # # # a(100) # 3、# __new__,和 __init__ # class B: # def fn(self): # print("B-fn") # def __init__(self): # print("B-init") # # class A: # def fn(self): # print("A-fn") # def __new__(cls, a): # print("new",a) # if a > 10: # return super(A,cls).__new__(cls) # return B # def __init__(self,a): # print("init",a) # # # a1 = A(5) # # a1.fn(1) # # a2 = A(20) # # a2.fn() # 4、list or dict # ls = [1,2,3,4] # list1 = [i for i in ls if i>2] # print(list1) #[3, 4] # # list2 = [i*2 for i in ls if i>2] # print(list2) #[6, 8] # # dic1 = {x:x**2 for x in (2,4,6)} # print(dic1) #{2: 4, 4: 16, 6: 36} # # dic2 = {x:'item'+str(x**2) for x in (2,4,6)} # print(dic2) #{2: 'item4', 4: 'item16', 6: 'item36'} # # set1 = {x for x in 'hello world' if x not in 'low level'} # print(set1) #{'d', 'h', 'r'} # 6、全局or局部 # num = 9 # def f1(): # global num # num = 20 # # print(num) # def f2(): # print(num) # f2() # f1() # f2() # class A: # def __init__(self,a,b): # self.a1 = a # self.b1 = b # print("init") # def mydefault(self): # print("default") # def __getattr__(self, item): # print("getattr") # return self.mydefault() # # a1 = A(10,20) # a1.fn1() # __all__ = ["mod2","mod1"] # 卸载iniit里,只导入这两个模块 # # def mulby(num): # def gn(val): # return num * val # return gn # # zw = mulby(7) # print(zw(6)) def strtest(num): str1 = "first" for i in range(num): str1 +="x" return str1 # python的str是个不可变对象,每次迭代,都会生成新的str对象来存储新的字符串,num越大,创建的str对象越多,内存消耗越大。 # numbers = [x*x for x in range(20) if x % 3 == 0] # numbers = {x * x for x in range(0, 20) if x % 3 == 0} # numbers = {x: x * x for x in range(0, 20) if x % 3 == 0} a = "I love python" reverse_a = a[::-1] print(reverse_a) cities = ["beijin","tianjin","shenzhegn"] for index,city in enumerate(cities,1): print(index,":",city)
def fn(x): return x * x map(fn,[1,2,3]) map(lambda x:x*x,[1,2,3]) l = [x for x in range(10)] # 列表 print(l) g = (x for x in range(10)) #生成器 print(g) # 统计一篇文章里出现的某个单词的次数 from collections import Counter import re def computercount(word): wordlist = Counter(re.split("\W+",word)) return wordlist x = "wo zhi dao wo shi keyi zuo de wo shi ni da ye" # print(computercount(x)) # 函数返回多个值 def fx(): error_code = 0 error_desc = "success" return error_code,error_desc code,desc = fx() print(code,desc) # 找出列表中出现次数最多的数 nums = [1,1,1,1,1,2,3,3,4,5,4,6,4,7] print(max(set(nums),key=nums.count))